test 

Volume in drive E is 001206_1632 
Volume Serial Number is 33CE-90D1 



Directory of E: \ 



12/06/00 04:32p <DIR> 
12/06/00 04:32p <DIR> 
12/06/00 04:33p <DIR> 
3 File(s) 



e-speak-src_991217 
0 bytes 



Directory of E:\e-speak-src_991217 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
3 File(s) 



platform 
0 bytes 



Directory of E:\e-speak-src_991217\platform 



C.12/06/00 
:l2/06/00 
^2/06/00 



04:33p 
04:33p 
04:33p 
3 



<DIR> 
<DIR> 
<DIR> 



File (s) 



ES 
0 bytes 



^Directory of E:\e-speak-src_991217\platform\ES 



,12/06/00 


04 


: 33p 


<DIR> 






1^2/06/00 


04 


:33p 


<DIR> 






-12/06/00 


04 


: 33p 


<DIR> 




bin 


•32/06/00 


04 


: 33p 


<DIR> 




conf ig 


12/15/99 


04 


:00p 




54,294 


configure 


1=12/15/99 


04 


: OOp 




10,314 


configure . in 


12/07/99 


04 


: 25p 




53 


conf igure. nt 


12/06/00 


04 


:33p 


<DIR> 




contrib 


12/07/99 


04 


:25p 




15,413 


COPYING 


12/07/99 


04 


:25p 




23,237 


COPYING. LIB 


12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/06/00 


04 


: 33p 


<DIR> 




extern 


12/07/99 


04 


:25p 




20,163 


HowTo.html 


12/15/99 


04 


:00p 




4,224 


include. mk. in 


12/15/99 


04 


:00p 




13, 149 


Makefile . in 


12/07/99 


04 


: 25p 




1, 509 


make . rules 


12/06/00 


04 


: 33p 


<DIR> 




samples 


12/06/00 


04 


: 33p 


<DIR> 




src 


12/06/00 


04 


: 33p 


<DIR> 




tutorial 






19 Filei 


(s) 


142,356 


> bytes 
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test 

Directory of E:\e-speak-src_991217\platform\ES\bin 



12/06/00 


04 


:33p 


<DIR> 




• 


12/06/00 


04 


:33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/07/99 


04 


:25p 




2,040 


envmake 


12/07/99 


04 


:25p 




2,007 


envmake.bat 


12/07/99 


04 


:25p 




2, 673 


envset 


12/07/99 


04 


:25p 




27 


eshome . bat 


12/07/99 


04 


:25p 




7,292 


genenv.pl 


12/15/99 


04 


:00p 




17, 909 


install .pi 


12/07/99 


04 


:25p 




35,269 


run . pi 



10 File(s) 67,217 bytes 



Directory of E:\e-speak-src_991217\platform\ES\bin\CVS 



12/06/00 
12/06/00 
iH2/16/99 
12/16/99 
•42/16/99 
:..d2/16/99 



04:33p 
04:33p 
06:18p 
06:17p 
06:17p 
06:17p 
6 



<DIR> 
<DIR> 



File (s) 



321 Entries 
31 Repository 
46 Root 

846 Template 
1,244 bytes 



III Directory of E:\e-speak-src_991217\platform\ES\config 



=12/06/00 


04 


: 33p 


<DIR> 






-12/06/00 


04 


:33p 


<DIR> 






112/06/00 


04 


: 33p 


<DIR> 




CO 


-12/07/99 


04 


:25p 




22 


col 


1.2/07/99 


04 


:25p 




22 


co2 


312/07/99 


04 


:25p 




22 


codef 


212/07/99 


04 


:25p 




133 


core . ini 


12/06/00 


04 


:33p 


<DIR> 




CVS 


12/07/99 


04 


:25p 




1, 039 


default . ini 


12/07/99 


04 


:25p 




149 


espeak_ldap . prop 


12/06/00 


04 


: 33p 


<DIR> 




management 


12/07/99 


04 


:25p 




25 


multiplecf . cf g 


12/07/99 


04 


:25p 




510 


repository . ini 


12/07/99 


04 


:25p 




17 


sample. cfg 



14 File(s) 1,939 bytes 



Directory of E:\e-speak-src_991217\platform\ES\config\co 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/07/99 04:25p 22 col 

12/07/99 04:25p 22 colO 
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test 



12/07/99 


04:25p 


22 


col . stress 


12/07/99 


04 :25p 


22 


co2 


12/07/99 


04:25p 


22 


co2 . stress 


12/07/99 


04:25p 


22 


co3 


12/07/99 


04:25p 


22 


co3. stress 


12/07/99 


04 :25p 


22 


co 4 


12/07/99 


04:25p 


30 


CO . SVEN . OMNIBOOK1 


12/07/99 


04:25p 


22 


co4 . stress 


12/07/99 


04:25p 


22 


co5 


12/07/99 


04:25p 


30 


co. SVEN. OMNI BOOK 


12/07/99 


04:25p 


22 


co5 . stress 


12/07/99 


04:25p 


22 


co6 


12/07/99 


04:25p 


24 


CO . PHIL . OMNI 3 


12/07/99 


04:25p 


22 


Co7 


12/07/99 


04:25p 


22 


co8 


12/07/99 


04:25p 


22 


co 9 


12/07/99 


04:25p 


24 


CO.PHIL.OMNI4 


12/07/99 


04:25p 


32 


CO . CHIA . CHOWCHOW1 


,42/07/99 


04:25p 


24 


co.PHIL.IUl 


:l2/07/99 


04:25p 


24 


CO. PHIL. IU24 


S2/07/99 


04 :25p 


33 


CO . SVEN . KAYAK1 


112/07/99 


04:25p 


22 


co . CHIA. localhost 


:ll2/07/99 


04:25p 


22 


co . MYC03 


112/07/99 


04:25p 


24 


CO.PHIL.OMNI2 


$2/07/99 


04:25p 


32 


co.CHIA.CHOWCHOW 


112/07/99 


04:25p 


24 


co.PHIL.IU23 


,12/07/99 


04:25p 


33 


CO . SVEN . KAYAK 


142/07/99 


04:25p 


22 


CO.MYC02 


: f 2/07/99 


04:25p 


24 


co. PHIL. OMNI 


i§2/07/99 


04:25p 


24 


co.PHIL.IU22 


lf2/07/99 


04:25p 


22 


co.MYCOl 


:J2/0 7/99 


04 : 25p 


30 


co.CHIA.OMNIBOOKl 


1312/07/99 


04:25p 


24 


co. PHIL. IU2 


12/07/99 


04:25p 


22 


co.MYCO 


12/07/99 


04:25p 


30 


CO.CHIA.OMNIBOOK 


12/06/00 


04:33p <DIR> 




CVS 




40 File(s) 


906 


> bytes 



Directory of E:\e-speak-src_991217\platform\ES\config\ 



co 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 

6 File(s 



<DIR> 
<DIR> 



1,736 Entries 
37 Repository 
4 6 Root 
84 6 Template 
2, 665 bytes 



Page 3 



test 

Directory of E:\e-speak-src_991217\platform\ES\config\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 420 Entries 

12/16/99 06:18p 32 Entries. Log 

12/16/99 06:18p 34 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

7 File(s) 1,378 bytes 

Directory of E:\e-speak-src_991217\platform\ES\config\management 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:25p 22 co2.dat 

12/06/00 04:33p <DIR> CVS 

12/06/00 04:33p <DIR> html 

,42/07/99 04:25p 980 management.ini 

j 6 File(s) 1,002 bytes 

J Directory of E : \e-speak-src_991217\platf orm\ES\conf ig\management\CVS 

il.2/06/00 04:33p <DIR> 
112/06/00 04:33p <DIR> 

;l2/16/99 06:18p 98 Entries 

,12/16/99 06:18p 14 Entries. Log 

0.2/16/99 06:18p 45 Repository 

1112/16/99 06:18p 46 Root 

•3-2/16/99 06:18p 846 Template 

ffll 7 File(s) 1,04 9 bytes 

n Directory of E:\e-speak-src_991217\platform\ES\config\management\html 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/06/00 04:33p <DIR> images 

12/07/99 04:25p 687 main.html 

12/07/99 04:25p 882 servlet . properties 

6 File(s) 1,569 bytes 

Directory of E:\e-speak-src 991217\platf orm\ES\conf ig\management\html 
\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 104 Entries 
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12/16/99 
12/16/99 
12/16/99 
12/16/99 



06:18p 
06:18p 
06: 18p 
06:18p 

7 



File(s) 



test 

16 Entries. Log 
50 Repository 
4 6 Root 
84 6 Template 
1,062 bytes 



Directory of E:\e-speak-src_991217\platform\ES\config\management\html 
\ images 



12/06/00 
12/06/00 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:25p 
04:33p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
9 



<DIR> 
<DIR> 

<DIR> 



File (s) 



6,840 Closed.gif 
CVS 

6,910 Error.gif 
6,852 Initializing.gif 
5,058 logo.gif 
6,897 Ready.gif 
6,880 Running.gif 
39,437 bytes 



3 Directory of E: \e-speak-src_991217\platf orm\ES\conf ig\raanagement\html 
, ;| images \CVS 



2/06/00 
2/06/00 
12/16/99 
12/16/99 
112/ 16/ 9 9 
42/16/99 



04:33p 
04:33p 
06:18p 
06: 18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File(s) 



288 Entries 
57 Repository 
4 6 Root 

84 6 Template 
1,237 bytes 



Q Directory of E:\e-speak-src_991217\platform\ES\contrib 



12/06/00 
12/06/00 
12/06/00 
12/06/00 
12/06/00 
12/15/99 
12/06/00 
12/06/00 



04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
04 : OOp 
04:33p 
04:33p 



<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 

<DIR> 
<DIR> 



8 File(s) 



browser 
CVS 

gsysmon 
245 Makefile 
sysmon 
vf s 
245 bytes 



Directory of E:\e-speak-src_991217\platform\ES\contrib\b 



rowser 



12/06/00 04:33p 
12/06/00 04:33p 
12/07/99 04:25p 



<DIR> 
<DIR> 



3,280 Browser. java 
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i ? /n fi /no 


U4 . J jp 




C02T6 






\ L> J. 




12/15/99 


04 :00p 




991 Makefile 


12/06/00 


04:33p 


<DIR> 


tree 


12/06/00 


04:33p 


<DIR> 


ui 


12/06/00 


04:33p 


<DIR> 


util 




9 


File (s) 


4,271 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\browser\core 



12/06/00 
12/06/00 
12/07/99 
12/06/00 
12/07/99 



04:33p 
04:33p 
04:40p 
04:33p 
04:40p 
5 



<DIR> 
<DIR> 

<DIR> 



File (s) 



12,861 CoreBrowser . java 
CVS 

390 Makefile 
13,251 bytes 



Directory of E: \e-speak-src_991217\platf orra\ES\contrib\browser\core\C 



''12/06/00 
12/06/00 
^2/16/99 
J.2/16/99 
212/16/99 
L12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File(s) 



101 Entries 
48 Repository 
46 Root 

846 Template 
1,041 bytes 



HjDirectory of E: \e-speak-src_991217\platf orm\ES\contrib\browser\CVS 



52/06/00 
-12/06/00 
52/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
06:18p 

7 File(s) 



<DIR> 
<DIR> 



97 Entries 
54 Entries. Log 
43 Repository 
4 6 Root 
84 6 Template 
1,086 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\browser\tree 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 



<DIR> 
<DIR> 



246 a.gif 

247 alert.red.gif 
242 alert.black.gif 

2,326 apache_pb.gif 

1, 573 AttributePropertyNode . j ava 

Page 6 



test 



12/07/99 


04:25p 


2, 096 


AttributeNode . j ava 


12/07/99 


04 :25p 


216 


back cfif 


12/07/99 


04 :25p 


205 


ball. red . gif 


12/07/99 


04:25p 


233 


ball . gray . gif 


12/07/99 


04 :25p 


2, 558 


BaseNode . j ava 


12/07/99 


04 : 25p 


246 


binarv . aif 


12/07/99 


04:25p 


246 


binhex . gif 


12/07/99 


04:25p 


148 


blank • gif 


12/07/99 


04:25p 


308 


bomb . gif 


12/07/99 


04 :25p 


251 


boxl . gif 


12/07/99 


04:25p 


268 


box2 . aif 


12/07/99 


04:25p 


247 


brokpn aif 


12/07/99 


04 : 25p 


235 


burst ai f 


12/07/99 


04 ■ 25d 


242 


c rri *F 


12/07 /99 


04 * 25n 


1 O^R 


ico ocu . y i j. 


12/07/99 


04 * 25d 


246 


rornn ay^v rri "F 

Ksnifys • u i. ci y • v_j i i 


12/07/99 


04 :25p 


251 


cottvd blue aif 


12/07 /99 


04 :25o 


214 

C~ 1 *1 


pont inn pf] rri f 


12/07 /99 


04 : 25p 


1, 933 


cticiiiuy ^ ^_ai\ uuc • j o v a 


^12/06/00 


04 : 33d 


<DIR> 


TVS 


;%2/07/99 


04 : 25p 


225 


dir . gif 


12/07/99 


04 : 25p 


163 


Hnwn rr "i *F 

VJ.v_/ W 1 A » U 1 1 


^12/07/99 


04 : 25p 


238 


dvi . q i f 


j .!l2/07/99 


04 • 25d 


1 621 

1 ^ \J 1 


LiU^Uil LL Q'-' L-iN^La" _ Java 


li.2/07/99 


04 :25p 


1, 619 


ESNarnpFr"ampNodp iflva 


iH.2/07/99 


04 : 25p 


1, 729 


i-J Oil 1 v_/ \1 • j ci V d 


"12/07/99 


04:25p 


1, 436 


ESVocabu la rvModp i^vs 

l_i V \_< Ci _l_ CA 1 V IX v*/ vl • 1 d V Ci 


"12/07/99 


04:25p 


236 


f .gif 


32/07/99 


04 :25p 


225 


foldpr aif 


•.^2/07/99 


04 :25p 


243 


folder . sec _ aif 


^2/07/99 


04 : 25p 


242 


folder oDpn ni f 


.'^2/07/99 


04 : 25p 


219 


forward csi f 


^2/07/99 


04 :25p 


221 


aeneric aif 


'12/07/99 


04 :25p 


249 


aeneri c ser* ai f 


12/07/99 


04:25p 


220 


aeneric. red aif 


12/07 /99 


04 • 25d 


223 


iiaiiu, • li^_' t vjii 


12/07/99 


04:25p 


217 


hand.riaht aif 


12/07/99 


04:25p 


11, 977 


icon. sheet aif 


12/07/99 


04:25p 


274 


imagel . gif 


12/07/99 


04:25p 


309 


imaae2 . aif 


12/07/99 


04 :25p 


286 


i ae ^ aif 


12/07/99 


04:25p 


1, 467 


InboxNode . j ava 


12/07/99 


04:25p 


268 


index.gif 


12/07/99 


04 :25p 


276 


layout . gif 


12/07/99 


04:25p 


172 


left . gif 


12/07/99 


04:25p 


249 


link. gif 


12/15/99 


04:00p 


969 


Makefile 


12/07/99 


04:25p 


243 


movie . gif 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
J.2/07/99 
412/07/99 
.H2/07/99 
,12/07/99 
!il2/07/99 
:J.2/07/99 
:£L2/07/99 
U2/07/99 
12/07/99 
"12/07/99 
52/07/99 
!|2/07/99 
12/07/99 
•S2/07/99 
•32/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:25p 

04:25p 

04:25p 

04:25p 

04:25p 

04:25p 

04:25p 

04:25p 

04:25p 

04:25p 

04:25p 

04:25p 

04:25p 

04:25p 

04:25p 

04:25p 

04 :25p 

04:25p 

04:25p 

04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04 :25p 
04:25p 
04:25p 
04:25p 
04 :25p 
04:25p 
04:25p 
04:25p 
04:25p 

96 File(s) 



test 

237 p.gif 
251 patch.gif 
249 pdf.gif 

188 pie0.gif 
198 piel.gif 
198 pie2.gif 
191 pie3.gif 
193 pie4.gif 

189 pie5.gif 
186 pie6.gif 
185 pie7.gif 
173 pie8.gif 
254 portal.gif 

1,4 58 ProtectionDomainNode . java 

244 ps.gif 
267 quill.gif 

1, 438 ResourceDescriptionNode. java 

172 right.gif 
1,400 RSDMapNode. java 
1,7 68 RsdNode.java 

258 screwl.gif 

2 63 screw2.gif 

242 script.gif 

248 soundl.gif 

221 sound2.gif 

285 spherel.gif 

264 sphere2.gif 

219 tar.gif 

251 tex.gif 

229 text.gif 

242 transfer.gif 
2,334 TreeBrowser . java 
2,435 TreeCellRenderer . java 
3,427 TreeNodeFactory. java 
8,315 TreeResourceVisitor . j ava 

245 unknown.gif 
164 up.gif 

236 uu.gif 
236 uuencoded.gif 
228 worldl.gif 
261 world2.gif 
71,673 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\browser\tree\C 

vs 



12/06/00 
12/06/00 



04:33p 
04 :33p 



<DIR> 
<DIR> 
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12/16/99 
12/16/99 
12/16/99 
12/16/99 



06:18p 
06:18p 
06: 18p 
06:18p 

6 File(s) 



test 
4,506 
48 
46 
846 



Entries 

Repository 

Root 

Template 



5,446 bytes 



Directory of E : \e-speak-src_991217\platform\ES\contrib\browser\ui 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
.J2/07/99 
'32/07/99 
32/07/99 
.12/07/99 
,12/15/99 
42/07/99 
$2/07/99 
#2/07/99 
L12/07/99 
[12/07/99 
$2/07/99 



04:33p 
04:33p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:33p 
04:25p 
04 :25p 
04:25p 
04:25p 
04:00p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 

21 File(s) 



<DIR> 
<DIR> 



<DIR> 



1,816 BrowserApp. j ava 
4,628 Browser Frame. j ava 
1,7 80 BrowserView. java 
2,397 BrowserToolBar . java 
4,539 BrowserStatusBar. java 
1,555 BrowserMenuBar . java 
5,285 Connect Dig. java 
CVS 

2,699 FileMenu. java 
2,842 HelpMenu. java 

172 left.gif 
2,081 ListPane . j ava 

861 Makefile 
3,291 Number Field. java 

172 right.gif 
2,326 TreePane. java 
1,310 Utility. java 
3,722 ViewMenu. java 
1,388 ViewTypes . java 
42,864 bytes 



^Directory of E : \e-speak-src_991217\platf orm\ES\contrib\browser\ui\CVS 



T2/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04 :33p 
06: 18p 
06:18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File (s) 



923 Entries 
4 6 Repository 
4 6 Root 

84 6 Template 
1,861 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\contrib\browser\util 



12/06/00 
12/06/00 
12/07/99 
12/06/00 
12/07/99 



04:33p 
04:33p 
04:25p 
04:33p 
04 :25p 



<DIR> 
<DIR> 

<DIR> 



2,687 Application. java 
CVS 

8, 388 DefaultResourceVisitor. java 
Page 9 



12/07/99 


04 


:25p 


12/07/99 


04 


: 25p 


12/07/99 


04 


: 25p 


12/07/99 


04 


:25p 


12/15/99 


04 


: OOp 


1Z/ (J / / 9 9 


04 


: 25p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 



16 Filets) 



test 

5,27 8 ExternalResource. java 
2,667 FrameworkVocabulary. java 
1,517 FrameworkException. java 
3,131 FrameworkContext . java 
878 Makefile 
11,438 PrintResourceVisitor . java 
2,484 PrintTreeFactory. java 
2,981 ResourceVisitor . java 
5,682 ResourceProvider . java 
5,381 ResourceDiscover . java 
3,180 VocabularyFinder . java 
55,692 bytes 



Directory of E:\e-speak-src_991217\platform\ES\contrib\browser\util\C 



12/06/00 
12/06/00 
^12/16/99 
112/16/99 
42/16/99 
12/ 16/ 9 9 



04:33p 
04:33p 
06:18p 
06:18p 
06: 18p 
06:18p 
6 



<DIR> 
<DIR> 



File(s) 



753 Entries 
48 Repository 
4 6 Root 
846 Template 
1,693 bytes 



Directory of E:\e-speak-src_991217\platform\ES\contrib\CVS 



"12/06/00 
r.12/06/00 
,3-2/16/99 
=3.2/16/99 
&2/16/99 
&2/16/99 
212/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06: 18p 
06:18p 
06:18p 

7 File(s) 



<DIR> 
<DIR> 



48 Entries 
63 Entries. Log 
35 Repository 
4 6 Root 
84 6 Template 
1,038 bytes 



Directory of E:\e-speak-src_991217\platform\ES\contrib\gsysmon 



12/06/00 
12/06/00 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/15/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:25p 
04:33p 
04:25p 
04:25p 
04: OOp 
04:25p 
04:25p 
9 



<DIR> 
<DIR> 

<DIR> 



File(s) 



5,116 BarSur f ace . java 
CVS 

1,806 Graphlntf . java 
7,034 GraphSur face. java 

533 Makefile 
8,439 SysMonGui. java 
7,198 TGFrame. java 
30,126 bytes 
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test 

Directory of E: \e-speak-src_991217\platf orm\ES\contrib\gsysmon\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 305 Entries 

12/16/99 06:18p 43 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 1,240 bytes 



Directory of E:\e-speak-src_991217\platform\ES\contrib\sysmon 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:25p 386 Makefile 

12/07/99 04:25p 8,877 SysMon.java 

5 File(s) 9,263 bytes 

% Directory of E:\e-speak-src_991217\platform\ES\contrib\sysraon\CVS 

ul.2/06/00 04:33p <DIR> 

^12/06/00 04:33p <DIR> 

1*1.2/16/99 06:18p 96 Entries 

^12/16/99 06:18p 42 Repository 

:J12/16/99 06:18p 46 Root 

"12/16/99 06:18p 846 Template 

!l, t 6 File(s) 1,030 bytes 

JSC s 

Directory of E:\e-speak-src_991217\platform\ES\contrib\vfs 

:5|2/06/00 04:33p <DIR> 

: 3f 2/06/00 04:33p <DIR> 

^12/06/00 04:33p <DIR> config 

12/06/00 04:33p <DIR> CVS 

12/06/00 04:33p <DIR> src 

5 File(s) 0 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\contrib\vf s\conf ig 



12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


:33p 


<DIR> 






12/07/99 


04 


:25p 




20 


col 


12/07/99 


04 


:25p 




20 


co2 


12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/07/99 


04 


:25p 




2,895 


Makefile 


12/07/99 


04 


:25p 




1,147 


Makefile.bat 


12/07/99 


04 


: 25p 




135 


VFSBrowser . ini 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
13 



File(s) 



test 

272 VFSBrowser.prop 
147 VFSFileStore.ini 
448 VFSFileStore .prop 
137 VFSShell.ini 
272 VFSShell.prop 
5,493 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\conf ig\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 



<DIR> 
<DIR> 



6 File(s) 



486 Entries 
46 Repository 
46 Root 

84 6 Template 
1,424 bytes 



Directory of E:\e-speak-src_991217\platform\ES\contrib\vfs\CVS 



112/06/00 

:fi2/o6/oo 

,12/16/99 
Si.2/16/99 
■12/16/99 
3i2/16/99 
ll2/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06: 18p 
06:18p 
7 



<DIR> 
<DIR> 



File(s) 



3 Entries 
29 Entries. Log 
39 Repository 
46 Root 
84 6 Template 
963 bytes 



rljDirectory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src 



j|2/06/00 04:33p <DIR> 

112/06/00 04:33p <DIR> 

(i2/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

4 File(s} 



CVS 
vf s 
0 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
06:18p 
7 



<DIR> 
<DIR> 



File (s; 



3 Entries 
13 Entries. Log 
43 Repository 
4 6 Root 
846 Template 
951 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s \src\vf s 
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test 



12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


• 33d 


<DTR> 

\ LJ -L L\-^ 




12/06/00 


04 


:33p 


<DIR> 


clientaD 


12/06/00 


04 


:33p 


<DIR> 


CVS 


12/06/00 


04 


: 33p 


<DIR> 


intf 


12/07/99 


04 


:25p 




450 Makefile 


12/06/00 


04 


:33p 


<DIR> 


server 


12/06/00 


04 


:33p 


<DIR> 


shell 


12/06/00 


04 


: 33p 


<DIR> 


util 






10 Filei 


(s) 


450 bytes 



Directory of E: \e-speak-src_991217\platform\ES\contrib\vf s\src\vf s\br 
owser 



12/06/00 
12/06/00 
12/07/99 
Cfi.2/07/99 
%2/07/99 
'"1.2/07/99 
fl2/07/99 
J12/07/99 
^12/07/99 
:t 12/07/99 
^12/07/99 
!' 3.2/06/00 
$L2/07/99 
1,8.2/07/99 
d2/07/99 
:i.2/07/99 
d2/07/99 
42/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04 : 33p 
04:25p 
04:25p 
04 :25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:33p 
04 :25p 
04:25p 
04:25p 
04:25p 
04 :25p 
04:33p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 



<DIR> 
<DIR> 



<DIR> 



<DIR> 



4,924 AttributeViewListener . java 
31,720 AttributeView. java 
2,616 Attributeltem. java 
25,061 Browser. java 

472 Browser . resources 
106,734 BrowsePane. java 

4,296 BrowsePane . resources 
7,855 BrowseDialog. java 
11, 116 CabinetAttributesDialog . java 
CVS 

2,47 6 DirectoryNode . java 

1,614 DragData . java 

6,742 Filelnfo. java 

9,936 FileStoreListDialog. java 

7,950 FolderWatcher . java 
images 

7,139 InputDialog. java 
10,419 LaunchFile. java 

1,120 Makefile 

5,151 MessageBoxOnTop. java 
15,865 NewFileDialog. java 
10,893 ProgressDialog. java 

6,824 PropertiesDialog . java 
41,781 SearchPane . java 

5,214 SearchPane . resources 
11,054 SelectCabinetDialog. java 
10, 32 6 SelectCabinetDialog . resources 

3,472 SplashScreen. java 
235,548 SplashScreen. resources 

1,805 SysImageList . java 



Page 13 



12/07/99 04:25p 

33 File(s) 



test 

7,510 TreeWatcher . java 
597,633 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\br 
owser\CVS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 1,610 Entries 

12/16/99 06:18p 16 Entries. Log 

12/16/99 06:18p 55 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

7 File(s) 2,573 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\br 
owser\images 



12/06/00 


04 


: 33p 


<DIR> 








'42/06/00 


04 


: 33p 


<DIR> 








42/06/00 


04 


: 33p 


<DIR> 






CVS 


'12/07/99 


04 


:25p 




9, 


484 


FILECOPY.AVI 


!lM.2/07/99 


04 


:25p 




1, 


238 


HPLogo . bmp 


112/07/99 


04 


:25p 






766 


LCabClose. ICO 


lfi2/07/99 


04 


:25p 






766 


LCabOpen. ICO 


1M.2/07/99 


04 


:25p 






766 


LFile. ICO 


'12/07/99 


04 


:25p 






766 


LFLDClose.ICO 


■12/07/99 


04 


:25p 






766 


LFLDOpen. ICO 


;^2/07/99 


04 


:25p 






318 


SCabClose.ICO 


:|f2/07/99 


04 


:25p 






318 


SCabOpen. ICO 


112/07/99 


04 


:25p 




20, 


796 


SEARCH . AVI 


12/07/99 


04 


:25p 






318 


SFile.ICO 


32/07/99 


04 


:25p 






318 


SFLDClose.ICO 


"12/07/99 


04 


:25p 






318 


SFLDOpen.ICO 



16 File(s) 36,938 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\br 
owser\ images \CVS 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 634 Entries 

12/16/99 06:18p 62 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 1,588 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\cl 
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test 



-1_ \^ il L CI -L* 












1 9/0 6/00 






<P)TR> 






12/06/00 


04 


: 33p 


<DIR> 






1 9 /06 /DO 


04 








V o 


1 9 /07 /QQ 


04 


• 9 Sn 




707 


rid Jvclxlc 


1 9 /07 /QQ 


04 


• 9 Sn 




9 091 


T\*T /-s U 1 n i Q -f- £i T7'/-\i innPvr" dr^-h ~i ^ y\ ~i -3 tt — > 

rjor licDLurer ounuijAOcpLion . j ava 


1 9 /07 /QQ 


04 


• 9 Sn 

. Z. J kJ 




^ ft 9 ^ 
3 f 0 Z 3 


v r or lieoioreLonurdCu . j ava 


1 9 /07 /QQ 


04 


• 9 Rn 




9 £ 0 07 


V r or llc^aDinet . j ava 


1 9 /07 /QQ 


04 






P 719 


v r or uore v ocsDUXciry . j ava 


12/07/99 


04 


: 25p 




10, 222 






04 


:25p 




l! 969 


VFSFileStoreElement . j ava 


12/07/99 


04 


:25p 




4,040 


VFSFileStoreDescription. java 


12/07/99 


04 


:25p 




26, 604 


VFSFolder . java 


12/07/99 


04 


:25p 




10,343 


VFSResourceVocabulary . java 


12/07/99 


04 


:25p 




5,781 


VFSResourceContract . j ava 


12/07/99 


04 


:25p 




28,252 


VFSWor kSpace . j ava 



15 File(s) 



130,169 bytes 



^Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\cl 
i*£entapi\CVS 



ii2/06/00 
^2/06/00 
S2/16/99 
J2/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 

6 File(s) 



<DIR> 
<DIR> 



712 Entries 
57 Repository 
46 Root 

846 Template 
1, 661 bytes 



^Directory of E : \e-speak-src 991217\platf orm\ES\contrib\vf s\src\vf s\CV 



T2/06/00 


04: 


33p 


<DIR> 






12/06/00 


04: 


33p 


<DIR> 






12/16/99 


06: 


18p 




48 


Entries 


12/16/99 


06: 


18p 




95 


Entries .Log 


12/16/99 


06: 


18p 




47 


Repository 


12/16/99 


06: 


18p 




46 


Root 


12/16/99 


06: 


18p 




846 


Template 



7 File(sJ 



1,082 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\in 
tf 



12/06/00 
12/06/00 
12/06/00 



04:33p 
04:33p 
04:33p 



<DIR> 
<DIR> 
<DIR> 



CVS 
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test 



1 9 /07 / Q Q 


04 


• 9 Sn 


JjO 


rJaKclllt; 


1 9 /07 /QQ 
j_ / u / / y y 






^ £7 0 


vron llciull . Java 


19/01/99 


04 




1,849 


VFSFilelntfMessageRegistry . java 


12/07/99 


04 


:25p 


10,400 


VFSFileStub. java 


12/07/99 


04 


:25p 


8, 982 


VFSFileStoreStub. java 


12/07/99 


04 


: 25p 


2,223 


VFSFileStorelntfMessageRegistry 


. java 










12/07/99 


04 


:25p 


4, 145 


VFSFileStorelntf . j ava 






10 File(s) 


33,825 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\in 
tf \CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
,12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File (s) 



411 Entries 
52 Repository 
46 Root 

84 6 Template 
1,355 bytes 



"'Directory of E: \e-speak-src 991217\platf orm\ES\contrib\vf s\src\vf s\se 



rver 



^2/06/00 
/06/00 
/06/00 
/07/99 
/15/99 
/07/99 
/07/99 
/07/99 
/07/99 



:i2 

"12 
i'12 
%2 

:X2 

%2 



12, 



04:33p 
04:33p 
04:33p 
04:25p 
04:00p 
04:25p 
04:25p 
04:25p 
04:25p 
9 



<DIR> 
<DIR> 
<DIR> 



File(s) 



CVS 

9,327 DumpVFSEntries . java 
542 Makefile 

5,319 StartFileStore. java 
10,836 VFSFileStoreService. java 
25,820 VFSFileStorelmpl. java 
13,228 VFSFilelmpl. java 

65,072 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\se 
rver\CVS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 332 Entries 

12/16/99 06:18p 54 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 Filets) 1,278 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\sh 
ell 
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test 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
..12/07/99 
412/07/99 
?i2/07/99 
'12/07/99 
^12/07/99 
i2/07/99 
:"l2/07/99 
12/07/99 
"12/07/99 
!' .12/07/99 
£12/07/99 



04:33p 


<DIR> 


04:33p 


<DIR> 


04:33p 


<DIR> 


04:25p 




04 :25p 




04:25p 




04:25p 




04:25p 




04:25p 




04:25p 




04:25p 




04 :25p 




04:25p 




04:25p 




04:25p 




04:25p 




04:25p 




04:25p 




04:25p 




04:25p 




04:25p 




04:25p 




04 :25p 




04:25p 




04:25p 




04:25p 




04:25p 




04:25p 





28 File(s; 



CVS 

Makefile 

VFScatComraand . j ava 
VFScdCommand . j ava 
VFSCommand . j ava 
10,028 VFScpCommand. java 
3,111 VFSechoCommand. java 
VFS execCommand. java 
VFSexport Command . j ava 
VFSf indCommand. java 
VFSimportCommand. java 
VFS Is Command. java 

VFSmkdirCommand. java 
VFSmkf ileCommand. java 
VFSmvCommand . j ava 
VFSpwdCommand . j ava 
VFSresetCommand . j ava 
VFSrmCommand . j ava 
VFS rmdir Command. java 
VFSsetCommand . j ava 
5,986 VFSshareCommand. java 
1,776 VFSShellException. java 
15,4 96 VFSShell. java 
7,593 VFSshowCommand. java 
1,775 VFSStackExcept ion. java 
3,280 VFSStack. java 
179,656 bytes 



967 
3,469 
3,830 
20, 179 



7,278 

5, 660 
12,226 

8,167 
10, 912 
5,754 
6,212 
14, 992 
2, 901 
4,576 
10,724 

6, 855 
5,909 



llli\2vs° rY ° f E:Xe " Speak - SrC - 991217X P latform \ ES \^ntrib\vfs\ S rc\vf S \sh 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File(s) 



1, 379 
53 
46 
846 
2,324 



Entries 
Repository- 
Root 

Template 
bytes 



^Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\ut 



12/06/00 04:33p 
12/06/00 04:33p 
12/06/00 04:33p 



<DIR> 
<DIR> 
<DIR> 



CVS 
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test 

12/07/99 04:25p 401 Makefile 

12/07/99 04:25p 3,469 VFSSt rings . java 

5 File(s) 3,870 bytes 

Directory of E: \e-speak-src_991217\platform\ES\contrib\vf s\src\vf s\ut 
il\cvs 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 100 Entries 

12/16/99 06:18p 52 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 1,044 bytes 



Directory of E:\e-speak-src_991217\platform\ES\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

fii.2/16/99 06:17p 431 Entries 

112/16/99 06:22p 110 Entries. Log 

"12/16/99 06:17p 27 Repository 

; 42/16/99 06: 17p 46 Root 

12/16/99 06:17p 846 Template 

f- 7 File(s) 1,460 bytes 

^ Directory of E:\e-speak-src_991217\platform\ES\extern 

:.i2/06/00 04:33p <DIR> 
'42/06/00 04:33p <DIR> 

j i2/06/00 04:33p <DIR> CVS 

22/06/00 04:33p <DIR> ldap 

22/06/00 04:33p <DIR> openxml 

! <f 2/06/00 04:33p <DIR> oracle-lib 

6 File(s) 0 bytes 



Directory of E:\e-speak-src_991217\platform\ES\extern\CVS 



12/06/00 


04:33p 


<DIR> 






12/06/00 


04: 33p 


<DIR> 






12/16/99 


06:18p 




3 


Entries 


12/16/99 


06:18p 




51 


Entries .Log 


12/16/99 


06: 18p 




34 


Repository 


12/16/99 


06:18p 




46 


Root 


12/16/99 


06:18p 




846 


Template 



7 File(s) 980 bytes 



Directory of E:\e-speak-src_991217\platforrn\ES\extern\ldap 



Page 18 



test 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> CVS 

12/08/99 01:52p 160,475 ldapjdk.jar 

4 File(s) 160,475 bytes 

Directory of E:\e-speak-src_991217\platform\ES\extern\ldap\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 51 Entries 

12/16/99 06:18p 39 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 982 bytes 

Directory of E:\e-speak-src_991217\platform\ES\extern\openxml 

92/06/00 04 : 33p <DIR> 

;i2/06/00 04:33p <DIR> 

/&/06/00 04:33p <DIR> CVS 

!|2/08/99 01:49p 357,071 openxml.jar 

;| 4 File(s) 357,071 bytes 

^Directory of E: \e-speak-src_991217\platf orm\ES\extern\openxml\CVS 

;l2/06/00 04:33p <DIR> 

j3i2/06/00 04:33p <DIR> 

^•2/16/99 06:18p 51 Entries 

"2:2/16/99 06:18p 42 Repository 

3*2/16/99 06:18p 46 Root 

tf2/16/99 06:18p 846 Template 

6 File(s) 985 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\extern\oracle-lib 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/08/99 01:57p 800,174 classeslll.zip 

12/06/00 04:33p <DIR> CVS 

4 File(s) 800,174 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\extern\oracle-lib\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 54 Entries 
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test 



12/16/99 


06:18p 




45 Repository 


12/16/99 


06:18p 






12/16/99 


06:18p 




o fi o l eiup idle 




6 


File (s) 


yyi cytes 


Directory of E:\e-speak-src ! 


yyizi / \pxa cioriu\ho \sarripxes 


12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 


echo 


12/06/00 


04:33p 


<DIR> 


ESChat 


12/07/99 


04:25p 




290 Makefile 


12/06/00 


04:33p 


<DIR> 


ManagedEcho 


12/06/00 


04:33p 


<DIR> 


ManagedPrint Server 


12/06/00 


04:33p 


<DIR> 


PrintServer 



9 File(s) 290 bytes 



^Directory of E:\e-speak-src_991217\platform\ES\samples\CVS 



'H2/06/00 04:33p 

H2/06/00 04:33p 

^2/16/99 06:18p 

[ J.2/16/99 06:19p 

;fi2/16/99 06:18p 

^2/16/99 06:18p 

12/16/99 06:18p 
; s 7 

fait 

^[Directory of E:\e-speak-src__991217\platform\ES\samples\echo 



'32/06/00 


04 


: 33p 


<DIR> 




: S2/06/00 


04 


: 33p 


<DIR> 




^2/06/00 


04 


: 33p 


<DIR> 


conf ig 


12/06/00 


04 


:33p 


<DIR> 


CVS 


12/07/99 


04 


:25p 




4,998 echo.vjp 


12/07/99 


04 


:25p 




4,127 README . txt 


12/06/00 


04 


:33p 


<DIR> 


src 






7 


File (s) 


9,125 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\echo\conf ig 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/07/99 04:25p 25 col.MYCO 

12/07/99 04:25p 26 co2.MYC0 

12/06/00 04:33p <DIR> CVS 

12/06/00 04:33p <DIR> multicore 



<DIR> 
<DIR> 

48 Entries 
100 Entries. Log 
35 Repository 
4 6 Root 
84 6 Template 
File(s) 1,075 bytes 
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test 

12/06/00 04:33p <DIR> singlecore 

7 File(s) 51 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\echo\conf ig\CV 

S 



12/06/00 


04:33p <DIR> 




12/06/00 


04:33p <DIR> 




12/16/99 


06:19p 


93 Entries 


12/16/99 


06:19p 


39 Entries. Log 


12/16/99 


06:19p 


47 Repository 


12/16/99 


06:19p 


4 6 Root 


12/16/99 


06:19p 


846 Template 




7 File(s) 


1,071 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\samples\echo\conf ig\mu 
lticore 



12/06/00 04:33p <DIR> 
C12/06/00 04:33p <DIR> 

'112/07/99 04:25p 64 client. prop 

"12/06/00 04:33p <DIR> CVS 

42/07/99 04:25p 744 EchoClient.ini 

Cf 2/07/99 04:25p 730 EchoServer.ini 

; l2/07/99 04:25p 42 server. prop 

\¥ 7 File(s) 1,580 bytes 

" Directory of E:\e-speak-src_991217\platform\ES\samples\echo\config\mu 
:;iticore\CV3 

22/06/00 04:33p <DIR> 
;f 2/06/00 04:33p <DIR> 

§2/16/99 06: 19p 201 Entries 

f #2/16/99 06:19p 57 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,150 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\samples\echo\conf ig\si 
nglecore 



12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


:33p 


<DIR> 






12/07/99 


04 


:25p 




60 


client . prop 


12/06/00 


04 


:33p 


<DIR> 




CVS 


12/07/99 


04 


:25p 




199 


EchoClient . ini 


12/07/99 


04 


:25p 




328 


EchoServer . ini 


12/07/99 


04 


:25p 




60 


server. prop 
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7 File(s) 



test 

647 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\echo\conf ig\si 
nglecore\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 201 Entries 

12/16/99 06:19p 58 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,151 bytes 

Directory of E: \e-speak-src_991217\platform\ES\samples\echo\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 95 Entries 

JL2/16/99 06:19p 29 Entries. Log 

412/16/99 06:19p 40 Repository 

H2/16/99 06: 19p 46 Root 

12/16/99 06:19p 846 Template 

7 File(s) 1,056 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\samples\echo\src 

; 12/0 6/00 04: 33p <DIR> 
, : 12/06/00 04:33p <DIR> 

42/06/00 04:33p <DIR> CVS 



: 42/07/99 04:25p 5,216 EchoServer . java 

32/07/99 04:25p 6,205 EchoClient . java 

32/07/99 04:25p 2,397 EchoServicelntf . esidl 

32/07/99 04:25p 3,838 EchoServiceStub . java 

'Tl'2/07/99 04:25p 1,388 EchoServicelntfMessageRegistry . 
java 

12/07/99 04:25p 2,397 EchoServicelntf . java 

12/07/99 04:25p 2,103 EchoServicelmpl . java 

12/07/99 04:25p 22,016 echoUML.doc 
12/07/99 04:25p 661 Makefile 

12 File(s) 46,221 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\samples\echo\src\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 501 Entries 

12/16/99 06:19p 44 Repository 

12/16/99 06:19p 46 Root 
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12/16/99 06:19p 

6 File(s) 



test 

846 Template 
1,437 bytes 



Directory of E:\e-speak-src_991217\platforra\ES\samples\ESChat 



12/06/00 
12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/06/00 



04:33p 
04:33p 
04:33p 
04:33p 
04:25p 
04:33p 
6 



<DIR> 
<DIR> 
<DIR> 
<DIR> 

<DIR> 



File(s) 



conf ig 
CVS 

3,550 README . txt 
src 
3,550 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\ESChat\conf ig 



12/06/00 
12/06/00 
12/06/00 
..,12/06/00 
-12/06/00 



04:33p 
04:33p 
04:33p 
04 :33p 
04:33p 
5 



<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 



File (s) 



CVS 

multicore 
singlecore 
0 bytes 



f Directory of E : \e-speak-src_991217\platf orm\ES\samples\ESChat\conf ig\ 

ijEVS 



;^2/06/00 
T.2/06/00 
"12/16/99 
22/16/99 
^2/16/99 
'12/16/99 
32/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
06:18p 

7 File(s) 



<DIR> 
<DIR> 



3 Entries 
39 Entries. Log 
49 Repository 
4 6 Root 
846 Template 
983 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\samples\ESChat\conf ig\ 
multicore 



12/06/00 


04 


:33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 






12/07/99 


04 


:25p 




58 


client .pr 


12/06/00 


04 


:33p 


<DIR> 




CVS 


12/07/99 


04 


:25p 




757 


ESChatServer. ini 


12/07/99 


04 


:25p 




164 


ESChatClient.ini 


12/07/99 


04 


: 25p 




570 


ESChatAddCore . ini 


12/07/99 


04 


:25p 




58 


server . pr 



8 File(s) 1,607 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\ESChat\conf ig\ 
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multicore\CVS 



test 



12/06/00 


04:33p 


<DIR> 


12/06/00 


04:33p 


<DIR> 


12/07/99 


04:25p 




12/06/00 


04:33p 


<DIR> 


12/07/99 


04:25p 




J2/07/99 


04:25p 




'€2/07/99 


04:25p 






7 File(s) 





12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 255 Entries 

12/16/99 06:18p 59 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 1,206 bytes 

Directory of E:\e-speak-src_991217\platform\ES\samples\ESChat\config\ 

smglecore y 



57 client. pr 

CVS 

740 ESChatServer.ini 
204 ESChatClient.ini 
57 server. pr 
1,058 bytes 

iKgxecoreXC^ 

j|2/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

1^2/16/99 06:18p 201 Entries 

;|2/16/99 06:18p 60 Repository 

=§2/16/99 06:18p 46 R / ot 

§2/16/99 06:18p 846 Template 

§ 6 File(s) 1,153 bytes 

'^Directory of E:\e-speak-src_991217\platform\ES\samples\ESChat\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18 P 50 Entr ie S 

06:18p 29 Entries. Log 

W^V^L ° 6:18P 42 repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Temp iate 

7 File(s) 1,013 bytes 

Directory of E:\e-speak-src_991217\platform\ES\samples\ESChat\ 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 



src 
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test 



1 7 /[)! / QQ 


04 


■ +J 


3 4 66 




12/06/00 


04 


:33p 


<DIR> 


CVS 


12/07/99 


04 


:25p 


23,040 


ESChatUML.doc 


12/07/99 


04 


:25p 


9 r 527 


ESChat .java 


12/07/99 


04 


:25p 


404 


Makefile 


12/07/99 


04 


:25p 


3,219 


MessageDialog. java 


12/07/99 


04 


:25p 


3,185 


Subscriber Impl . j ava 



9 File(s) 42,841 bytes 



Directory of E: \e-speak-src_991217\platform\ES\samples\ESChat\src\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 312 Entries 

12/16/99 06:18p 46 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 1,250 bytes 

; ~jf Directory of E : \e-speak-src_991217\platf orm\ES\samples\ManagedEcho 

;l2/06/00 04:33p <DIR> 
S2/06/00 04:33p <DIR> 

LJ2/06/00 04:33p <DIR> config 

^2/06/00 04:33p <DIR> CVS 

! ? l2/07/99 04:25p 2,236 README . txt 

'12/06/00 04:33p <DIR> src 

l A 6 File(s) 2,236 bytes 

^{Directory of E : \e-speak-src_991217\platf orm\ES\samples\ManagedEcho\co 

!l2/06/00 04:33p <DIR> 
'#2/06/00 04:33p <DIR> 

12/07/99 04:25p 25 col.MYCO 

12/07/99 04:25p 26 co2.MYCO 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:25p 443 ManagedEcho.ini 

12/07/99 04:25p 108 testMgr.ini 

7 File(s) 602 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\ManagedEcho\co 
nfig\CVS 

12/06/00 04: 33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 193 Entries 

12/16/99 06:18p 54 Repository 
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test 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 1,139 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\samples\ManagedEcho\CV 

S 



12/06/00 


04:33p 


<DIR> 






12/06/00 


04:33p 


<DIR> 






12/16/99 


06:18p 




50 


Entries 


12/16/99 


06: 18p 




29 


Entries . Log 


12/16/99 


06:18p 




47 


Repository 


12/16/99 


06:18p 




46 


Root 


12/16/99 


06: 18p 




846 


Template 



7 File(s) 1,018 bytes 



Directory of E:\e-speak-src_991217 

c 



412/06/00 


04:33p 


<DIR> 




€2/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




: 32/07/99 


04:25p 




2, 


12/07/99 


04:25p 




2, 


$2/07/99 


04:25p 




1, 


: 1ava 








''12/07/99 


04:25p 




2, 


"12/07/99 


04:25p 




2, 


1-2/07/99 


04:25p 






:l2/07/99 


04:25p 




6, 


12/07/99 


04:25p 




2, 


1:2/07/99 


04:25p 




4, 




12 File(s) 


i 


23 



Directory of E:\e-speak-src_991217 
c\CVS 



\platf orra\ES\samples\ManagedEcho\sr 



CVS 

212 EchoServicelntf . esidl 

343 EchoServiceStub. java 

408 EchoServicelntfMessageRegistry . 

216 EchoServicelntf . java 

154 EchoServicelmpl . java 

688 Makefile 

077 ManagedEcho . java 

632 startManagedEcho. java 

196 testMgr.java 

,926 bytes 

\platform\ES\ samples \ManagedEcho\sr 



12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:18p 

12/16/99 06:18p 

12/16/99 06:18p 

12/16/99 06:18p 

6 File(s) 



<DIR> 
<DIR> 

509 Entries 

51 Repository 

4 6 Root 

84 6 Template 
1,452 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\samples\ManagedPrintSe 
rver 
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test 



12/06/00 


04 : 33p 


<DIR> 




12/06/00 


04 :33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 


conf ig 


12/06/00 


04:33p 


<DIR> 


CVS 


12/06/00 


04:33p 


<DIR> 


doc 


12/09/99 


06:44a 




5,800 README • txt 


12/06/00 


04:33p 


<DIR> 


SampleFiles 


12/06/00 


04:33p 


<DIR> 


src 




8 Filei 


(s) 


5,800 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\ManagedPrintSe 
rver\conf ig 



12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


:33p 


<DIR> 




12/06/00 


04 


:33p 


<DIR> 


CVS 


12/06/00 


04 


:33p 


<DIR> 


multicore 


12/07/99 


04 


:25p 




380 Print.ini 


.12/06/00 

Q 

'li 


04 


:33p 


<DIR> 


singlecore 




6 File(s; 




380 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\ManagedPrintSe 
;ffver\conf ig\CVS 



132/06/00 
:'l2/06/00 
12/16/99 
•12/16/99 
22/16/99 
:|2/16/99 
32/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
06:18p 

7 File(s; 



<DIR> 
<DIR> 



49 Entries 
39 Entries. Log 
61 Repository 
4 6 Root 
846 Template 
1,041 bytes 



^Directory of E: \e-speak-src_991217\platf orm\ES\ samples \ManagedPrintSe 
rver\conf ig\multicore 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:25p 42 Client. prop 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:25p 341 PC.ini 

12/07/99 04:25p 538 PC-Core. ini 

12/09/99 07:02a 1,696 PS . ini 

7 File(s) 2,617 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\samples\ManagedPrintSe 
rver\conf ig\rnulticore\CVS 
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12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04 :33p 
06:18p 
06:18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File(s) 



test 



185 Entries 
71 Repository 
46 Root 

84 6 Template 
1,148 bytes 



Directory of E: \e-speak-src_991217\platform\ES\samples\ManagedPrintSe 
rver\conf ig\singlecore 



42 Client. prop 
CVS 
220 PC.ini 
376 print.ini 
1,278 PS.ini 

42 Server. prop 
1, 958 bytes 



12/06/00 


04 


:33p 


<DIR> 


12/06/00 


04 


:33p 


<DIR> 


12/07/99 


04 


:25p 




12/06/00 


04 


:33p 


<DIR> 


12/07/99 


04 


:25p 




12/07/99 


04 


:25p 




12/09/99 


07 


:03a 




12/07/99 


04 


:25p 





8 Filets] 



% = Directory of E:\e-speak-src_991217\platform\ES\samples\ManagedPrintSe 
*tver\conf ig\singlecore\CVS 



j ?l2/06/00 
_l 12/06/00 
"12/16/99 
12/16/99 
1^2/16/99 
! M2/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06: 18p 
6 



<DIR> 
<DIR> 



File (s) 



231 Entries 
72 Repository 
4 6 Root 

846 Template 
1,195 bytes 



^Directory of E : \e- speak-src_99121 7 \platf orm\ES\ samples \ManagedPrintSe 



-tfver\CVS 






12/06/00 


04:33p <DIR> 




12/06/00 


04:33p <DIR> 




12/16/99 


06:18p 


50 Entries 


12/16/99 


06:18p 


63 Entries. Log 


12/16/99 


06: 18p 


54 Repository 


12/16/99 


06:18p 


4 6 Root 


12/16/99 


06: 18p 


84 6 Template 




7 File(s) 


1,059 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\ManagedPrintSe 
rver\doc 



12/06/00 04:33p 



<DIR> 



Page 28 



12/06/00 
12/06/00 
12/09/99 



04:33p 
04:33p 
07:01a 

4 File(s) 



<DIR> 
<DIR> 



test 

CVS 

56,647 Userguide.doc 
96, 647 bytes 



Directory of E: \e-speak-src_991217\platSorm\ES\samples\ManagedPrintSe 
rver\doc\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06: 18p 
6 



<DIR> 
<DIR> 



File(s) 



53 Entries 
58 Repository 
4 6 Root 
846 Template 
1,003 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\ManagedPrintSe 
rver\SampleFiles 



-42/06/00 
ft2/06/00 
.%2/06/00 
IJJ.2/07/99 
'J12/07/99 
;2l2/07/99 
'.12/07/99 
"12/07/99 



04:33p 
04:33p 
04:33p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 

8 File(s) 



<DIR> 
<DIR> 
<DIR> 



CVS 

181,760 test. doc 
351 test.ini 
6 test.ppt 
49 test.txt 
6 test.xls 
182,172 bytes 



Directory of E : \e-speak-src_991217 \platf orm\ES\samples\ManagedPrintSe 
;|fver\SarnpleFiles\CVS 



32/06/00 
42/C6/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File (s) 



228 Entries 
66 Repository 
4 6 Root 
84 6 Template 
1,186 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\ManagedPrintSe 
rver\src 



12/06/00 
12/06/00 
12/06/00 
12/15/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04 : OOp 
04:25p 



<DIR> 
<DIR> 
<DIR> 



CVS 

799 Makefile 
10,298 ManagedPrintService. java 
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12/07/99 


04 


:25p 

IT 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 



12 File(s) 



test 

6,133 PolicyWriter . j ava 

18,611 PrintClient . java 

3,805 PrinterStub. java 

1,884 Printerlntf . java 

14,133 Printerlmpl. java 

5,539 Print Joblnfo. java 

18,441 PrintServer . java 

79, 643 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\ManagedPrintSe 
rver\src\CVS 



12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:18p 

12/16/99 06:18p 

12/16/99 06:18p 

12/16/99 06:18p 

6 File(s] 



<DIR> 
<DIR> 



482 Entries 
58 Repository 
4 6 Root 

846 Template 
1,432 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\PrintServer 



;ft2/06/00 04:33p <DIR> 

!Ji2/06/00 04:33p <DIR> 

S12/06/00 04:33p <DIR> 

1*5.2/06/00 04:33p <DIR> 

'12/07/99 04:25p 

'12/06/00 04:33p <DIR> 

13.2/06/00 04:33p <DIR> 

% 7 File(s) 



conf ig 
CVS 

4,4 99 README . txt 
SampleFiles 
src 
4,499 bytes 



[St Directory of E:' 
3§f ig 


\e-speak-src 1 


991217 \platform\ES\saitipl< 


12/06/00 


04 


:33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


:33p 


<DIR> 




col 


12/06/00 


04 


: 33p 


<DIR> 




co2 


12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/06/00 


04 


:33p 


<DIR> 




multicore 


12/07/99 


04 


:25p 




297 


Print . ini 


12/07/99 


04 


: 25p 




1, 973 


printer . xml 


12/07/99 


04 


:25p 




1, 688 


printerl . xml 


12/07/99 


04 


:25p 




1,760 


printit.pl 


12/07/99 


04 


:25p 




1,571 


printVocab . xml 


12/06/00 


04 


:33p 


<DIR> 




singlecore 






12 


File (s) 


7,28 


9 bytes 
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test 

Directory of E: \e-speak-src_991217\platform\ES\samples\PrintServer\co 
nf ig\col 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:25p 25 col.MYCO 

12/06/00 04:33p <DIR> CVS 

4 File(s) 25 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\samples\PrintServer\co 
nfig\col\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 48 Entries 

12/16/99 06:18p 58 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 998 bytes 

'f\ Directory of E: \e-speak-src_991217\platf orm\ES\samples\PrintServer\co 
%f ig\co2 

^2/06/00 04:33p <DIR> 

22/06/00 04:33p <DIR> 

!|2/07/99 04:25p 25 co2.MYCO 

42/06/00 04:33p <DIR> CVS 

4 File(s) 25 bytes 

^Directory of E: \e-speak-src_991217\platf orm\ES\samples\PrintServer\co 
:Sfig\co2\CVS 

22/06/00 04:33p <DIR> 

T2/06/00 04:33p <DIR> 

12/16/99 06:18p 48 Entries 

12/16/99 06:18p 58 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 998 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\samples\PrintServer\co 
nfig\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 244 Entries 

12/16/99 06:18p 65 Entries. Log 

12/16/99 06:18p 54 Repository 
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test 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

7 File(s) 1,255 bytes 

Directory of E: \e-speak-src_991217\platf or^jJS\samples\PrintServer\co 
nf ig\multicore \ 



12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/07/99 


04 


:25p 




42 Client. prop 


12/06/00 


04 


: 33p 


<DIR> 


CVS 


12/07/99 


04 


:25p 




202 PC.ini 


12/07/99 


04 


:25p 




557 PC-Core. ini 


12/07/99 


04 


:25p 




817 PS. ini 






7 File (si 


) 


1,618 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\PrintServer\co 
nf ig\multicore\CVS 

-12/06/00 04:33p <DIR> 
#2/06/00 04:33p <DIR> 

"12/16/99 06:18p 185 Entries 

^12/16/99 06:18p 64 Repository 

J2/16/99 06:18p 46 Root 

j ii2/16/99 06:18p 846 Template 

6 File(s) 1,141 bytes 

] : Directory of E: \e-speak-src_991217\platf orin\ES\samples\PrintServer\co 
;5]f ig\singlecore 

2.2/06/00 04: 33p <DIR> 
32/06/00 04:33p <DIR> 

;32/07/99 04:25p 42 Client. prop 

-12/06/00 04:33p <DIR> CVS 

12/07/99 04:25p 184 PC.ini 

12/07/99 04:25p 426 PS. ini 

6 File(s) 652 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\PrintServer\co 
nf ig\singlecore\CVS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 137 Entries 

12/16/99 06:18p 65 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 1,094 bytes 
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test 



Directory of E : \e-speak-src_991217\platf orm\ES\samples\PrintServer\CV 

S 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 50 Entries 

12/16/99 06:18p 50 Entries. Log 

12/16/99 06:18p 47 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

7 File(s) 1,039 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\PrintServer\Sa 
mpleFiles 



12/06/00 


04 


:33p 


<DIR> 








12/06/00 


04 


:33p 


<DIR> 








.12/06/00 


04 


:33p 


<DIR> 




CVS 




€2/07/99 


04 


:25p 




181,760 


test 


.doc 


^2/07/99 


04 


:25p 




351 


test 


. ini 


12/07/99 


04 


:25p 




6 


test 


•PPt 


$2/07/99 


04 


:25p 




49 


test 


. txt 


j l2/07/99 


04 


:25p 




6 


test 


. xls 



8 File(s) 182,172 bytes 

'■^Directory of E: \e-speak-src_991217\platf orm\ES\samples\PrintServer\Sa 
hpleFiles\CVS 

j |!2/0 6/00 04:33p <DIR> 
i2/06/00 04:33p <DIR> 

fc/16/99 06:18p 228 Entries 

!lfe/16/99 06:18p 59 Repository 

tt/16/99 06:18p 4 6 Root 

12/16/99 06:18p 846 Template 

6 File(s) 1,179 bytes 



Directory of E: \e-speak-src_991217\platform\ES\sarrtples\PrintServer\sr 

c 



12/06/00 


04 


: 33p 


<DIR> 








12/06/00 


04 


:33p 


<DIR> 








12/06/00 


04 


: 33p 


<DIR> 






CVS 


12/15/99 


04 


:00p 






995 


Makefile 


12/07/99 


04 


:25p 




6, 


152 


Print Server . j ava 


12/07/99 


04 


:25p 




16, 


750 


PrintClient . j ava 


12/07/99 


04 


:25p 




2, 


375 


Print Joblnfo . esidl 


12/07/99 


04 


:25p 




2, 


524 


Print Joblnfo . j ava 
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test 



12/07/99 


04:25p 


60, 928 


12/07/99 


04:25p 


2,343 


12/07/99 


04:25p 


2, 958 


12/07/99 


04:25p 


1,574 


. java 






12/07/99 


04:25p 


2, 347 


12/07/99 


04:25p 


6, 187 



14 File(s) 



105, 133 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\PrintServer\sr 
c\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File (s] 



624 Entries 
51 Repository 
4 6 Root 

84 6 Template 
1,567 bytes 



'.^Directory of E:\e-speak-src_991217\platform\ES\src 



22/06/00 


04:33p 


<DIR> 




J2/06/00 


04:33p 


<DIR> 




!|2/06/00 


04:33p 


<DIR> 


c 


;tf2/06/00 


04:33p 


<DIR> 


CVS 


'12/06/00 


04:33p 


<DIR> 


java 


^2/06/00 


04:33p 


<DIR> 


perl 


;i2/06/00 


04:33p 


<DIR> 


python 



7 File(s) 0 bytes 

ST 

^Directory of E: \e-speak-src 991217\platform\ES\src\c 



'1*2/06/00 
12/06/00 
12/06/00 
12/06/00 



04:33p 
04:33p 
04:33p 
04:33p 

4 



<DIR> 
<DIR> 
<DIR> 
<DIR> 



File (s) 



cesi 
CVS 
0 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\c\cesi 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 



04:33p 
04:33p 
04 :25p 
04:25p 
04:25p 
04:25p 
04:33p 



<DIR> 
<DIR> 



<DIR> 



49,436 abi.c 
16,525 abi.h 
15,614 abi_base.c 
4,223 abi_base.h 
CVS 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:25p 
04 :25p 
04:25p 
04 :25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 

17 File(s) 



test 
19,827 
3,512 
620 
631 
408 
3,716 
8,036 
3,745 
5, 654 
13,071 
145,018 



eslib . c 
eslib.h 
makefile 
makef ile_w32 
README . txt 
rtc . c 
rts . c 
tec 
ts . c 

wservpipe . c 
bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\c\cesi\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
.12/16/99 
jj.2/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File (s; 



624 Entries 
38 Repository 
46 Root 

84 6 Template 
1,554 bytes 



g Directory of E:\e-speak-src_991217\platform\ES\src\c\CVS 



52/06/00 
^2/06/00 
12/16/99 
fl2/16/99 
:32/16/99 
'22/16/99 
22/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 
06:19p 

7 File (si 



<DIR> 
<DIR> 



3 Entries 
14 Entries. Log 
33 Repository 
4 6 Root 
84 6 Template 
942 bytes 



directory of E:\e-speak-src_991217\platform\ES\src\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04 :33p 
06:19p 
06:22p 
06:19p 
06:19p 
06:19p 

7 File(s) 



<DIR> 
<DIR> 



3 Entries 
55 Entries. Log 
31 Repository 
4 6 Root 
84 6 Template 
981 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java 



12/06/00 
12/06/00 



04 :33p 
04:33p 



<DIR> 
<DIR> 
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12/06/00 
12/07/99 
12/06/00 



04:33p 
04:25p 
04:33p 
5 



test 

<DIR> CVS 

187 Makefile 
<DIR> net 
File(s) 187 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06: 19p 
06: 19p 
06:19p 
06:19p 
06:19p 
7 



<DIR> 
<DIR> 



File(s] 



48 Entries 
13 Entries. Log 
36 Repository 
46 Root 
846 Template 



98 9 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net 



,42/06/00 04:33p <DIR> 
^2/06/00 04:33p <DIR> 
:jl2/06/00 04:33p <DIR> 
: 12/06/00 04:33p <DIR> 

4 File(s) 



CVS 

espeak 
0 bytes 



fjj Directory of E:\e-speak-src_991217\platform\ES\src\java\net\CVS 



12/06/00 
j.2/06/00 
142/16/99 
-12/16/99 
$2/16/99 
■12/16/99 
$2/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06: 19p 
06:19p 
06:19p 

7 File(s; 



<DIR> 
<DIR> 



3 Entries 
16 Entries. Log 

40 Repository 
46 Root 
846 Template 
951 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak 



12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 


CVS 


12/06/00 


04 


: 33p 


<DIR> 


infra 


12/06/00 


04 


: 33p 


<DIR> 


jesi 
477 Makefile 


12/07/99 


04 


:25p 




12/06/00 


04 


: 33p 


<DIR> 


services 


12/06/00 


04 


: 33p 


<DIR> 


util 


12/07/99 


04 


:25p 




2,099 Version. j 


12/06/00 


04 


: 33p 


<DIR> 


webaccess 






10 


File (s) 


2,576 bytes 



Page 36 



test 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\CV 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:21p 
06:19p 
06: 19p 
06:19p 
7 



<DIR> 
<DIR> 



File (s) 



97 Entries 
80 Entries. Log 
47 Repository 
46 Root 
84 6 Template 
1,116 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
fra 



12/06/00 
12/06/00 
,,12/06/00 
412/06/00 
:€2/06/00 
12/06/00 
■212/06/00 
;l2/07/99 
'22/06/00 



04:33p 


<DIR> 




04:33p 


<DIR> 




04:33p 


<DIR> 


cci 


04:33p 


<DIR> 


client 


04:33p 


<DIR> 


core 


04:33p 


<DIR> 


CVS 


04:33p 


<DIR> 


intercorecom 


04:25p 




269 Makefile 


04:33p 


<DIR> 


xml 


9 File(s] 


1 


269 bytes 



■^Directory of E: \e-speak-src_991217 \platf orm\ES\src\ j ava\net\espeak\in 
Lira \ cci 



32/06/00 


04 


:33p 


<DIR> 




32/06/00 


04 


: 33p 


<DIR> 




S2/06/00 


04 


: 33p 


<DIR> 


coreapi 


12/06/00 


04 


: 33p 


<DIR> 


coreproxy 


12/06/00 


04 


:33p 


<DIR> 


CVS 


12/06/00 


04 


: 33p 


<DIR> 


events 


12/06/00 


04 


: 33p 


<DIR> 


exception 


12/06/00 


04 


: 33p 


<DIR> 


export 


12/07/99 


04 


:25p 




357 Makefile 


12/06/00 


04 


: 33p 


<DIR> 


management 


12/06/00 


04 


: 33p 


<DIR> 


messaging 


12/06/00 


04 


: 33p 


<DIR> 


metadata 


12/06/00 


04 


: 33p 


<DIR> 


naming 


12/06/00 


04 


: 33p 


<DIR> 


security 






14 


File(s) 


357 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\cci\coreapi 
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test 



i 9 /nfi/nn 

± / U \J I UU 


04 


• 33n 


J. Z / U U / 


04 


• j jp 


1 9 /07 /QQ 


04 


* 9 Sn 


1 9 /07 / QQ 


04 


• 9 Sn 


1 9 /06/00 


04 




1 9 /07 /QQ 

J_ Z. / VJ / / J Z? 


04 


• 9 Sn 


12/07/99 


04 


: 2 5p 


1 9 /07 /QQ 


04 


• 9 Sn 


1 9 /07 / QQ 


04 


• 9 Sn 


1 9 / 07 / Q Q 




• 9 Sn 
. Z Dy 


19/07 / QQ 

±£. / \J I f Z? Z? 


0 4 


* 9 Sn 


19/07/QQ 


04 


• 9 Sn 

• z ^ £J 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


ava 






12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


J.2/07/99 


04 


:25p 


712/07/99 


04 


:25p 


*i2/07/99 


04 


:25p 



<DIR> 
<DIR> 



<DIR> 



19 Filets: 



6,485 CoreManagement Inter f ace. j ava 
8,572 CoreNames . java 
CVS 

8, 626 ImporterExporterlnterf ace . java 
2,698 Keylnterf ace. java 
4,645 KeyRinglnterf ace. java 
5,388 Mailboxlnterf ace. java 

805 Makefile 
9,933 NameFramelnterf ace . j ava 
5,301 ProtectionDomainlnterf ace . j ava 
6, 118 RepositoryViewInterf ace . java 
24, 869 ResourceManipulationlnterface . j 

3, 754 ResourceFactorylnterf ace. java 
3, 284 ResourceContractlnterface. java 
4,752 SystemMonitorlnterf ace. java 
5, 108 VocabularyToolboxInterf ace. java 
4,922 Vocabularylnterf ace . java 
105,260 bytes 



;4| Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
i5f ra\cci\coreapi\CVS 



.12/06/00 
i : 12/06/00 
ij2/16/99 
42/16/99 
42/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06: 19p 
06:19p 
6 



<DIR> 
<DIR> 



File (s) 



990 Entries 
65 Repository 
4 6 Root 

84 6 Template 
1, 947 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\cci\coreproxy 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/06/00 
12/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:33p 
04:26p 

6 File(s) 



<DIR> 
<DIR> 



<DIR> 



6. 240 ConnectionFactorylnterf ace. java 

4.241 CoreProxylnterf ace. java 
CVS 

400 Makefile 
10,881 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net \espeak\in 
f ra\cci\coreproxy\CVS 
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12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File (si 



test 



176 Entries 
67 Repository 
46 Root 

846 Template 
1,135 bytes 



Directory of E: \e-speak-src_991217\platf orra\ES\src\ java\net\espeak\in 
fra\cci\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04 :33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 
06: 19p 

7 File(s| 



<DIR> 
<DIR> 



48 Entries 
178 Entries. Log 

57 Repository 

46 Root 
846 Template 
1,175 bytes 



'^Directory of E : \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
¥ra\cci\events 

$2/06/00 

32/06/00 
l l l 2/07/99 
l= i2/06/00 
:12/C7/99 
(12/07/99 
:if2/07/99 
2i2/C7/99 



04 


: 33p 


<DIR> 






04 


: 33p 


<DIR> 






04 


:26p 




6,417 


CoreEvent . j ava 


04 


:33p 


<DIR> 




CVS 


04 


:26p 




5,705 


EventAttributeSet 


04 


: 26p 




7,891 


EventList . j ava 


04 


:26p 




14,456 


Event . j ava 


04 


:26p 




413 


Makefile 



8 File(s) 



34,882 bytes 



^Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\cci\e vents \CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File(s) 



256 Entries 
64 Repository 
4 6 Root 

84 6 Template 
1,212 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
f ra\cci\exception 



12/06/00 04:33p 



<DIR> 
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1 9 /Ofi /on 

-L Z / U U / U U 


04 * ^n 






1 9 /fl7 / QQ 


U ft . Z Dp 




9 41 Q 
z ^ f± x _? 


1 9 /n fi /on 

X Z / Uu/ UU 


A / - 9 9-n 
U ft • 3 -J JJ 






1 9 /07 /QQ 
x z / u / / y -? 


04*9 fin 
u ft . z op 




9 0 fi7 

Z , U O / 


1 9 /07 / QQ 
xz/u f / yy 


04-9 fin 

U 4 * Z Op 




ft 0ft 9 
o , u o z 


1 9 /07 / QQ 
X Z / U / / -7 _7 


u ft . z op 




o ^ u o o 


1 9 /07 /QQ 


u ft . z op 




9 4 0 4 

Z f ft U fi 


TO / A 7 / QQ 
XZ/U //_/_? 


0 4 • 9 £t~n 

u ft . z op 




1 R ^ Q 

x / o j y 


1 9 / H 7 / QQ 

Xz / U 1 1 yy 


A /I . 9 f? n 

u ft . z op 




9 ^ R ^ 
Z , OOO 


1 9 / fl 7 / QQ 

xz/u / / 


u h . z op 




9 77 ^ 


1 o / n *7 / QQ 


u ft . z op 




1 4 71 
/ r ft O X 


1 9 / n "7 / Q Q 

xz / u / / y y 


U4 . z op 




Z , ODD 


1 9 /D7 /QQ 

xz/u / / 


A /! • 9 fii^ 

u ft . z op 




9 4 R P 
Z; flOO 


1 9 /A7 / QQ 
XZ/U / / y y 


A A • 9 £r-\ 

u ft . z op 




9 /IRQ 
Z / ft D O 


1 9 / A7 / QQ 

xz/ u / / y y 


A /I . 9 

U4 : z op 




9 19 9 


1 9 /07 / Q Q 
XZ / u / / :? -> 


0/1-9 fir\ 

u ft . z op 




9 O Q9 
Z / U y Z 


1 9 / A 7 / QQ 

xz/u / / y y 


A A . 9 

u ft . z op 




4 /I 7 9 
ft / fi o Z 


19/07 /QQ 


04 * 9 fin 
u ft • z up 




9 904 

^. / Z U f± 


1 o / A7 / Q Q 

^z/u//yy 


A 4 • 9 

U 4 . Z Op 




9 1 RQ 
Z / XDo 


? ^9 / m / QQ 

( xz / u / / y y 


A A • 9 £r> 

u fi . z op 




1 Q c 
X , DO D 


f '¥ 9 / 0 7 / Q Q 
s-XZ / U / / y y 


04*9 fir>i 

u ft . z op 




9 4^4 
Z j ft D ft 


: V -a, 








; ";to /07 / QQ 
•i|i^Z / \J f / yy 


04-9 fin 

u ft . z op 




9 904 

Z j Z U ft 










i"o / n 7 / Q Q 

rpz / u / / y y 


A A * 9 £r-. 

Uft . z op 




9 n Q A 

z , u y 4 


i'O / A 7 / QQ 

jjfcZ/o //yy 


A /] . 9 

U4 : z bp 




9 A £ A 
Z , U o4 


.12/07/99 


04:26p 




2,143 


;12/07/99 


04:26p 




2,016 


f lO / A 7 / Q Q 

i^z / u / / y y 


A 4 . 9 

u ft . z op 




9 A 9 9 
Z , UZ Z 


4-9 / n 7 / Q Q 

r&jjZ / u / / y y 


A A . 9 

u ft . z op 




9 1 

Z , XDZ 


%9 707 /QQ 

! x^z / U » / _? -7 


04 • 9 fin 




9 fi4 9 

Z f U 4 z 


S-9 /A 7 / QQ 
joaZ / U / / yy 


0 4*9 

U4 i z op 




9 117 
Z f X X / 


TO /A7 / QQ 

xz/u//yy 


A /I • 9 

Uft • z op 




9 1 1 Q 

z , x x y 


1 9 /07 /QQ 


0 4 • 9 fin 

U *i - Z Up 




9 Ofifi 
z ^ u o o 


1 9 /A 7 / QQ 

xz/u //yy 


U4 t z op 




9 HOC 
Z f UDD 


Va 








1 9 / A 7 / QQ 

xz/u / /yy 


A A • 9 
U4 , z Op 




9 9 7/1 
Z , Z / 4 


1 9 /07 / QQ 
X Z / U i 1 y y 


04*9 fi-n 

u fi . z op 




9 Oft P 


12/07/99 


04 • 2 6n 




2 lift 


va 








12/07 /99 


04 • 2Sn 




2 4 
f. / t j j 


1 9 /07 / QQ 
x <l / u if y y 


04 • 9 fin 
u ft • z up 




9 1 fi4 

Z f X O ft 


12/07/99 


04:26p 




2,112 


12/07/99 


04:26p 




2,332 


ava 








12/07/99 


04:26p 




2,216 


java 









CVS 



2, 204 MultipleResolvedBindingExceptio 



Not ImportableException . j ava 



java 



2,216 UnrecoverableDeliveryException . 



Page 40 



test 

12/07/99 04:26p 2,009 UnresolvedBindingException . j ava 

43 File(s) 107,600 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
fra\cci\exception\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:19p 2,545 Entries 

12/16/99 06:19p 67 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 3,504 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
f ra\cci\export 

12/06/00 04:33p <DIR> 

,12/06/00 04:33p <DIR> 

■$2/06/00 04:33p <DIR> CVS 

:|2/07/99 04:26p 15,693 ExportFE. java 

J2/07/99 04:26p 27,068 ExportContext . java 

$2/07/99 04:26p 17,102 ImportContext . java 

$2/07/99 04:26p 397 Makefile 

\\ 7 File(s) 60,260 bytes 

^Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
lira \ccx\ export \CVS 

fc/06/00 04:33p <DIR> 

!|2/06/00 04:33p <DIR> 

•1J2/16/99 06:19p 208 Entries 

52/16/99 06:19p 64 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,164 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
r ra\cci\management 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 368 Makefile 

12/07/99 04:26p 3,081 ManagedServiceOpcodes . j ava 

5 File(s) 3,449 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
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f ra\cci\management\CVS 



test 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File(s) 



111 Entries 
68 Repository 
46 Root 

84 6 Template 
1,071 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\j ava\net\espeak\in 
f ra\cci\messaging 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
J.2/07/99 
=12/07/99 
M2/06/00 
&/07/99 
^2/07/99 
:|2/07/99 
Lfc/07/99 
$2/07/99 
12/07/99 
_12/07/99 
ii=2/07/99 
$2/07/99 
i|fe/07/99 
12/07/99 
12/07/99 
T2/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 

04:33p 

04:26p 

04:26p 

04:26p 

04:26p 

04:2 6p 

04:33p 

04:26p 

04:26p 

04:26p 

04:2 6p 

04:26p 

04:26p 

04 :26p 

04:26p 

04:2 6p 

04 :26p 

04 :26p 

04:26p 

04:2 6p 

04 :26p 

04:26p 

04:26p 

04:26p 

04:2 6p 

04:26p 

04 :26p 

04:26p 

04:2 6p 

04 :26p 

31 File(s) 



<DIR> 
<DIR> 



<DIR> 



4,702 BootstrapReply . java 
17,4 92 ChannelWriter . j ava 
23,263 ChannelReader. java 
20,951 Channel. java 
12,280 ClientChannel. java 
CVS 

3,284 ESSerializable. java 

6,155 FIFOQueue. java 
13,488 InboxMessageAtom. java 

9,259 IVMChannel. java 

7,410 IVMQueue. java 

2,697 IVMRendezvous . java 
962 Makefile 

7,804 Message. java 
14,287 MessageAtom. java 
34,717 MessageRegistry. java 
22,555 MessageOutputStream. java 
22,914 MessagelnputStream. java 

6,647 MessageBufferedStream. java 

4,358 MsgFilter. java 
12,195 OutboxMessageAtom. java 

4,369 PayloadReference. java 

4,380 PayloadFroraCore. java 

3,4 67 PayloadForCore. java 

3,8 69 Rendezvous . java 

6,153 Resourcelnfo. java 

3, 800 SysteniMonitorHelper . java 
12,380 TCPChannel. java 

3,22 9 TCPRendezvous. java 
289,067 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\in 
fra\cci\messaging\CVS 
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test 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06: 19p 
06:19p 
6 



<DIR> 
<DIR> 



File (s] 



1,538 Entries 
67 Repository 
4 6 Root 
846 Template 
2,497 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
f ra\cci\metadata 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
1.2/07/99 
: §2/06/00 
lfe/07/99 
.1:2/07/99 
'32/07/99 
£2/07/99 
IJ2/07/99 
fc/07/99 
12/07/99 
12/07/99 
12/07/99 
&/07/99 
ife/07/99 
'&/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:2 6p 
04:26p 
04:26p 
04:33p 
04:26p 
04:2 6p 
04 :26p 
04 :26p 
04:26p 
04:2 6p 
04:2 6p 
04 :2 6p 
04:26p 
04:26p 
04:2 6p 
04 :26p 
20 



<DIR> 
<DIR> 



<DIR> 



File (s) 



12,656 Attribute. java 
15,404 AttributeSet . java 

9,786 AttributePropertySet . java 
21,375 AttributeProperty. java 
10,960 AttributePredicate. java 
CVS 

29,182 ESUID.java 
704 Makefile 
1,756 Matcherlnterf ace. java 
3,7 60 NaraedObject. java 
1,759 Promoterlnterf ace. java 
31, 730 ResourceSpecif ication. java 
6,603 ResourceDescription. java 
RSD. java 

SearchRecipe . j ava 
SearchPredicate . j ava 
ValueType. java 
Value. java 



u, 575 
15, 618 
6, 406 
20, 342 
59, 374 



255,990 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
fra\cci\metadata\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04 :33p 
06:19p 
06:19p 
06:19p 
06: 19p 
6 



<DIR> 
<DIR> 



File (s) 



929 Entries 
66 Repository 
4 6 Root 

84 6 Template 
1,887 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\cci\naming 
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12/06/00 
12/06/00 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
9 



<DIR> 
<DIR> 

<DIR> 



File(s) 



test 



3,069 Accessor . j ava 
CVS 

27,188 ESName.java 
7,868 LiteralName . j ava 

441 Makefile 
7,453 NameSearchPolicy . java 
4,852 ResourceReference. java 
50,871 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
f ra\cci\naming\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
,12/16/99 
112/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06: 19p 
06:19p 
6 



<DIR> 
<DIR> 



File(s) 



316 Entries 
64 Repository 
4 6 Root 

84 6 Template 
1,272 bytes 



^Directory of E: \e-speak-src_991217 \platf orm\ES\src\ java\net\espeak\in 
ifxaXccixsecurity 



m 



,12/06/00 
'12/06/00 
.12/06/00 
4?2/C7/99 
&/07/99 
|S/07/99 
Ife/07/99 



04:33p 
04:33p 
04:33p 
04 :26p 
04 :26p 
04:26p 
04 :26p 
7 



<DIR> 
<DIR> 
<DIR> 



File (s) 



CVS 

2,22 8 Lockable . java 

6,335 LockedPermissions . java 

4,131 Lock. java 

394 Makefile 
13,088 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\ 
fra\cci\security\CVS 



in 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File (s) 



203 Entries 
66 Repository 
4 6 Root 

84 6 Template 
1,161 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\ 
fra\client ^ 



in 
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test 



12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


:33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/07/99 


04 


:26p 




12/06/00 


04 


: 33p 


<DIR> 






10 


File(s) 



clientapi 
coreproxy 
corestubs 
CVS 

exception 
impl 
301 Makefile 
util 
301 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net \espeak\i 
f ra\client\clientapi 



n 



12/06/00 
12/06/00 
12/06/00 
J.2/07/99 
'#2/07/99 
"12/07/99 
,"12/07/99 
iSt2/07/99 
!|2/07/99 
32/07/99 
J2/07/99 
;.12/07/99 
42/07/99 
1*2/07/99 
i|2/07/99 
$2/07/99 
$2/07/99 
•$2/07/99 



04 :33p 
04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:2 6p 
04:26p 
04 :26p 
04:26p 
04:26p 
04:26p 

18 File(s] 



<DIR> 
<DIR> 
<DIR> 



CVS 

2,613 ESContractlntf . java 

3,793 ESInboxIntf . java 

2,216 ESIntf.java 

3,218 ESKeylntf . java 

3,368 ESKeyRinglntf . java 
10,319 ESNameFramelntf . java 

3, 936 ESProtectionDomainlntf . java 

3,788 ESRemoteObjlntf . java 
13,674 ESRLIntf . java 

3,361 ESServicelntf . java 
40,793 ESShelllntf . java 

3,018 ESSystemMonitorlntf . java 

3,339 ESViewIntf . java 

3,267 ESVocabularylntf . java 
674 Makefile 
101,377 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
fra\client\clientapi\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File (s) 



818 Entries 
7 0 Repository 
4 6 Root 
84 6 Template 
1,780 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\clxent\coreproxy - 
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test 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 33,299 ESConnectionFactory . j ava 

12/07/99 04:26p 7,074 ESCoreProxy . java 

12/07/99 04:26p 390 Makefile 

6 File(s) 40,763 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
f ra\client\coreproxy\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 162 Entries 

12/16/99 06:19p 70 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,124 bytes 

Directory of E: \e-speak-src_991217\platforra\ES\src\java\net\espeak\in 
; f ra\client\corestubs 

Ul 

ill 

^12/06/00 04:33p <DIR> 
$.2/06/00 04:33p <DIR> 

|l2/06/00 04:33p <DIR> CVS 

: ; '12/07/99 04:26p 12, 959 ImporterExporter . java 

iJ.2/07/99 04:26p 8, 599 Interf aceToCore . j ava 

^2/07/99 04:26p 5, 527 KeyRing.java 

142/07/99 04:26p 3,281 Key. java 

$2/07/99 04:26p 7,386 Mailbox. java 

§2/07/99 04:26p 642 Makefile 

,42/07/99 04:26p 17,945 NameFrame . java 

12/07/99 04:26p 6,081 ProtectionDomain . j ava 

12/07/99 04:26p 9,201 RepositoryView . j ava 

12/07/99 04:26p 42,410 ResourceManipulation . j ava 

12/07/99 04:26p 4,920 ResourceFactory . j ava 

12/07/99 04:26p 3,469 ResourceContract . java 

12/07/99 04:26p 5,250 SystemMonitor . java 

12/07/99 04:26p 5,396 Vocabulary . java 

17 File(s) 133,066 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
fra\client\corestubs\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 755 Entries 
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test 

12/16/99 06:19p 70 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,717 bytes 

Directory of E : \e-speak-src_991217 \platf orm\ES\src\ j ava\net \espeak\in 
fra\client\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 48 Entries 

12/16/99 06:19p 104 Entries. Log 

12/16/99 06:19p 60 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

7 File(s) 1,104 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
^raXclientXexception 

32/06/00 04:33p <DIR> 
= 5(2/06/00 04:33p <DIR> 

j|2/07/99 04:26p 2,505 CoreNotFoundException . j ava 

&2/06/00 04:33p <DIR> CVS 

$2/07/99 04:26p 409 Makefile 

J2/07/99 04:26p 2,937 UnexpectedExceptionException. ja 



ya 



6 File(s) 5,851 bytes 



-Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
(§ ra\client \except ion\CVS 

$2/06/00 04:33p <DIR> 

f 2/06/00 04:33p <DIR> 

12/16/99 06:19p 181 Entries 

12/16/99 06:19p 70 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,143 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\clxent\impl 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 5,506 ESContract . java 

12/07/99 04 :26p 9,352 ESCoreManagementService . j ava 
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test 


12/07/99 


04:26p 


17, 920 


12/07/99 


04:26p 


8,421 


12/07/99 


04:26p 


7,753 


12/07/99 


04:26p 


4,747 


12/07/99 


04:26p 


17,440 


va 






12/07/99 


04:26p 


23,204 


12/07/99 


04:26p 


8,391 


12/07/99 


04:26p 


10,068 


12/07/99 


04:26p 


36, 740 


12/07/99 


04:26p 


3,837 


12/07/99 


04:26p 


112,191 


12/07/99 


04:26p 


6, 037 


12/07/99 


04:26p 


13,322 


12/07/99 


04:26p 


9,792 


12/07/99 


04:26p 


8,090 


12/07/99 


04 :26p 


738 


12/07/99 


04:26p 


16, 647 




22 File(s) 


320, 196 



java 



^Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\ 
j|ra\client\impl\CVS 



12/06/00 
12/06/00 
.12/16/99 
:.12/16/99 
,012/16/99 
&2/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File(s) 



1,011 Entries 
65 Repository 
46 Root 
84 6 Template 
1,968 bytes 



^Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\ 
:=ira\client\util 



12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/07/99 


04:26p 




10, 093 


12/06/00 


04:33p 


<DIR> 


12/07/99 


04:26p 




4,571 


12/07/99 


04:2 6p 




2, 699 


12/07/99 


04:26p 




4, 557 


12/07/99 


04:26p 




635 


12/07/99 


04:2 6p 




12,720 


12/07/99 


04:26p 




16,524 


12/07/99 


04 :26p 




11, 781 


12/07/99 


04:26p 




5, 547 


12/07/99 


04:26p 




5, 919 


12/07/99 


04:26p 




4,811 



CoreNameList . java 
CVS 

ESPOPInfo. java 
ExtractException . j ava 
HelperMethods .java 
Makefile 

MessageState. java 
MessageHandler . java 
MethodPermissionMap. java 
MsgldentityFilter . java 
MsgRSDFilter . java 
ParameterList . j ava 
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test 

12/07/99 04:26p 5,598 ParamUnit . j ava 

12/07/99 04:26p 2,340 Trace. java 

12/07/99 04:26p 5,560 Userlnf o . j ava 

17 File(s) 93,355 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
fra\client\util\CVS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:19p 753 Entries 

12/16/99 06:19p 65 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,710 bytes 



Directory of E : \e-speak-src_9 91217 \plat f orm\ES\src\j ava\net\espeak\ in 













12/06/00 


04 


: 33p 


<DIR> 




52/06/00 


04 


:33p 


<DIR> 




,12/06/00 


04 


:33p 


<DIR> 


contract 


!i!2/06/00 


04 


: 33p 


<DIR> 


CVS 


j l2/06/00 


04 


: 33p 


<DIR> 


exception 


'$2/06/00 


04 


:33p 


<DIR> 


export 


;if2/06/00 


04 


: 33p 


<DIR> 


mailbox 


12/07/99 


04 


:4 0p 




443 Makefile 


fl2/06/00 


04 


:33p 


<DIR> 


management 


%2/06/QQ 


04 


:33p 


<DIR> 


naming 


;||2/o6/oo 


04 


:33p 


<DIR> 


pd 


£2/06/00 


04 


: 33p 


<DIR> 


plugins 


;fe/06/oo 


04 


:33p 


<DIR> 


quota 


:&/o6/oo 


04 


: 33p 


<DIR> 


repository 


T2/06/00 


04 


: 33p 


<DIR> 


resource 


12/06/00 


04 


:33p 


<DIR> 


router 


12/06/00 


04 


:33p 


<DIR> 


security 


12/06/00 


04 


: 33p 


<DIR> 


startup 


12/06/00 


04 


: 33p 


<DIR> 


sysmon 


12/06/00 


04 


:33p 


<DIR> 


util 


12/06/00 


04 


:33p 


<DIR> 


vocabulary 






21 Filei 


(s) 


443 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net \espeak\in 
f ra\core\contract 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:40p 12,648 Contract . j ava 
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12/06/00 
12/07/99 
12/07/99 



04:33p 
04:40p 
04 : 40p 

6 File(s) 



test 

<DIR> CVS 

375 Makefile 
2,666 RegistrylF. j ava 
15,689 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\core\contract\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File(s) 



150 Entries 
67 Repository 
46 Root 
846 Template 
1,109 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\core\CVS 



42/06/00 
:fl2/06/00 
,12/16/99 
$2/16/99 
:|2/16/99 
$2/16/99 
#2/16/99 



04:33p 
04:33p 
06:19p 
06:20p 
06:19p 
06:19p 
06:19p 

7 File{s) 



<DIR> 
<DIR> 



48 Entries 
289 Entries. Log 

58 Repository 

4 6 Root 
846 Template 
1,287 bytes 



'^Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\i 
iJra\core\exception 



in 



32/06/00 
32/06/00 
1*2/07/99 
12/06/00 
12/07/99 



04:33p 
04:33p 
04 : 40p 
04:33p 
04:40p 



<DIR> 
<DIR> 

<DIR> 



5 File(s) 



2, 531 AssertionFailedException. java 
CVS 

372 Makefile 
2,903 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\ 
fra\core\exception\CVS 



in 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06: 19p 
06:19p 

6 File(s) 



<DIR> 
<DIR> 



114 Entries 
68 Repository 
4 6 Root 

84 6 Template 
1,074 bytes 
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test 



f ra\core 


\ export 




12/06/00 


04:33p 


<DIR> 


12/06/00 


04:33p 


<DIR> 


12/06/00 


04:33p 


<DIR> 


12/07/99 


04: 4 Op 




12/07/99 


04:40p 




12/07/99 


04 : 40p 




12/07/99 


04:40p 




12/07/99 


04:40p 




12/07/99 


04 :40p 




12/07/99 


04 :40p 






10 


File(s) 



CVS 

5, 999 ExportMessagelnput Stream. java 
42,803 Exporter . java 

8,112 FrameMapEntry. java 
19,363 ImportExportNames. java 
26,94 9 Import erExporter . java 
55,249 Importer. java 

485 Makefile 
158,960 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
fra\core\export\CVS 

12/06/00 04:33p <DIR> 
K2/06/00 04:33p <DIR> 

;|2/16/99 06:19p 386 Entries 

$2/16/99 06:19p 65 Repository 

$2/16/99 06:19p 46 Root 

I12/16/99 06:19p 846 Template 

w 6 File(s) 1,343 bytes 

^Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
if a: a \ core \ma i lbox 

lfe/06/00 04:33p <DIR> 

&/06/00 04:33p <DIR> 

§2/07/99 04:40p 6, 974 ChannelWriterThread. j ava 

12/07/99 04:40p 2,655 ChannelWriterDaemon. j ava 

12/07/99 04:40p 6,985 ChannelThreadPool . j ava 

12/07/99 04:40p 4,675 CoreChannel . java 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:40p 10,995 Inbox. java 

12/07/99 04:40p 527 Makefile 

J2/07/99 04:40p 2,344 MessageQueuel tern. j ava 

12/07/99 04:40p 5,321 MessageQueue. java 

12/07/99 04:40p 10,818 Outbox.java 

12 File(s) 51,294 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\core\mailbox\CVS 

12/06/00 04:33p <DIR> 
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12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
06: 19p 
06:19p 
06:19p 
06:19p 
6 



<DIR> 



File (s) 



test 

489 Entries 
66 Repository 
4 6 Root 
84 6 Template 
1,447 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net \espeak\in 
f ra\core\management 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:40p 
04:40p 



<DIR> 
<DIR> 
<DIR> 



5 File(s) 



CVS 

372 Makefile 
16, 612 ManagedAbstractResource . java 
16,984 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
Jra\core\management\CVS 



!§2/06/00 
1:2/06/00 
:fc/16/99 
$2/16/99 
'$2/16/99 
ife/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File (s; 



113 Entries 
69 Repository 
46 Root 

84 6 Template 
1,074 bytes 



j=lPirectory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
!£{ra\core\naming 



32/06/00 
12/06/00 
52/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04 : 40p 
04:33p 
04:40p 
04:40p 
04:40p 
04:40p 
04:40p 
9 



<DIR> 
<DIR> 

<DIR> 



File (s) 



5,107 Binding. java 
CVS 

454 Makefile 
23,229 MappingObject . java 
94,368 NameFrame . j ava 

8,209 NameSearchPolicyMatcher. java 

6,580 PartialBinding. java 
137,947 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
fra\core\naming\CVS 



12/06/00 04:33p 
12/06/00 04:33p 
12/16/99 06:19p 



<DIR> 
<DIR> 



324 Entries 
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12/16/99 
12/16/99 
12/16/99 



06:19p 
06: 19p 
06: 19p 

6 File(s) 



test 

65 Repository 
4 6 Root 
84 6 Template 
1,281 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\core\pd 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04 :33p 
04 : 40p 
04 : 40p 
04:40p 
6 



<DIR> 
<DIR> 
<DIR> 



File (s) 



CVS 

377 Makefile 
30,042 ProtectionDomain. java 
5,997 WorkingSet . java 
36,416 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
fra\core\pd\CVS 



412/06/00 
1*12/06/00 
'12/16/99 
;£L2/16/99 
•12/16/99 
$2/16/99 



04:33p 
04:33p 
06: 19p 
06:19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File (s) 



158 Entries 
61 Repository 
4 6 Root 

846 Template 
1,111 bytes 



[^Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
5ra\core\plugins 



32/06/00 

42/06/00 
42/06/00 
'TT2/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
12/06/00 



04:33p 
04:33p 
04 :33p 
04 : 40p 
04:40p 
04: 4 Op 
04:40p 
04:33p 
04:33p 



9 Filets! 



<DIR> 
<DIR> 

<DIR> CVS 

393 Makefile 

3,4 95 PluglnLoader . java 

1,776 PluglnlF. java 

4,548 Plugln.java 

<DIR> secureboot 

<DIR> testplugin 
10,212 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net \espeak\in 
f ra\core\plugins\CVS 



12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:19p 

12/16/99 06:19p 



<DIR> 
<DIR> 



200 Entries 
40 Entries. Log 
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test 

12/16/99 06:19p 66 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

7 File(s) 1,198 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\core\plugins\secureboot 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:40p 4,395 SecureBoot . java 

4 File(s) 4,395 bytes 

Directory of E:\e-speak-src 991217\platf orm\ES\src\j ava\net \espeak\in 
fra\core\plugins\secureboot\CVS 

12/06/00 04:33p <DIR> 
J2/06/00 04:33p <DIR> 

'■$2/16/99 06:19p 55 Entries 

!€2/16/99 06:19p 77 Repository 

,^2/16/99 06:19p 46 Root 

'22/16/99 06:19p 846 Template 

% 6 File(s) 1,024 bytes 

^Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net \espeak\in 
'f ra\core\plugins\testplugin 

J2/O6/OO 04:33p <DIR> 

ii2/06/00 04:33p <DIR> 

;ife/06/00 04:33p <DIR> CVS 

i&/07/99 04:41p 1,915 TestPlugln. java 

S 4 File(s) 1,915 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net \espeak\in 
f ra\core\plugins\testplugin\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 55 Entries 

12/16/99 06:19p 77 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,024 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\in 
f ra\core\quota 
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test 



1 ? /Ofi/00 


04 


• 33r> 


<DTR> 






12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/07/99 


04 


:41p 




389 


Makefile 


12/07/99 


04 


:41p 




10, 189 


QuotaCheck . j ava 


12/07/99 


04 


:41p 




14,951 


QuotaSize . java 


12/07/99 


04 


:41p 




25,082 


Quota. j ava 



7 File(s) 50,611 bytes 



Directory of E : \e-speak-src_9 9 12 17 \platform\ES\sr c:\java\net\espeak\ in 
f ra\core\quota\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06: 19p 
06:19p 
6 



<DIR> 
<DIR> 



File(s) 



198 Entries 
64 Repository 
46 Root 

846 Template 
1,154 bytes 



V Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
/tra\core\repository 



112/06/00 


04 


:33p 


<DIR> 






42/06/00 


04 


: 33p 


<DIR> 






h 12/07/99 


04 


:41p 




14,917 


AbstractStore . j ava 


j l2/07/99 


04 


:41p 




7,254 


ActiveResourceOwners . j ava 


■12/07/99 


04 


:41p 




14, 960 


CacheEnt ry . j ava 


132/07/99 


04 


:41p 




10,740 


CacheStats . j ava 


112/07/99 


04 


:41p 




30,996 


Cache. java 


^2/06/00 


04 


: 33p 


<DIR> 




CVS 


32/07/99 


04 


:41p 




15,703 


DumpCore . j ava 


32/06/00 


04 


:33p 


<DIR> 




jdbc 


12/07/99 


04 


:41p 




771 


Makefile 


12/06/00 


04 


:33p 


<DIR> 




mem 


12/07/99 


04 


:41p 




17,870 


RepositoryView . j ava 


12/07/99 


04 


:41p 




4,437 


RepositoryReset . j ava 


12/07/99 


04 


:41p 




24, 681 


RepositoryHandle . j ava 


12/07/99 


04 


:41p 




30,283 


Repository . java 


12/07/99 


04 


:41p 




29,593 


Scavenger . j ava 


12/07/99 


04 


:41p 




3, 452 


StoreUnitsIF. java 


12/07/99 


04 


:41p 




8,091 


StoreUnitList . java 


12/07/99 


04 


:41p 




4,335 


StoreUnit . java 






20 


File(s) 


218,083 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\core\repository\CVS 
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12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:20p 
06:19p 
06:19p 
06:19p 
7 



<DIR> 
<DIR> 



File (s) 



test 



800 Entries 
27 Entries. Log 
69 Repository 
46 Root 

84 6 Template 
1,788 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
f ra\core\repository\ jdbc 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
,12/07/99 
43-2/07/99 
:%2/07/99 
'12/07/99 
!;J.2/07/99 

&2/07/99 

<|' 

Directory 
i'fra\core\r 



04:33p <DIR> 
04:33p <DIR> 
04:33p <DIR> 
04:41p 
04 :41p 
04:41p 
04:41p 
04:41p 
04:41p 
04:41p 
04:41p 
04:41p 

12 File(s) 

of E:\e-speak-src_ 
epository\jdbc\CVS 



CVS 

14,197 JDBCRepositoryHandle. java 
29,056 JDBCHouseKeeping. java 
31,040 JDBCResourceState. java 
13, 912 JDBCResourceSpecif ication. java 
10,243 JDBCResourceLookup. java 
22,361 JDBCResourceDescription . j ava 
17,317 JDBCSqlStrings. java 
16,847 JDBCStore. java 

57 6 Makefile 
155, 549 bytes 

991217 \platform\ES\src\java\net\espeak\in 



-12/06/00 04:33p 

32/06/00 04:33p 

32/16/99 06:20p 

;t2/16/99 06:19p 

"12/16/99 06:19p 

12/16/99 06:19p 

6 File(s) 



<DIR> 
<DIR> 



526 Entries 
74 Repository 
4 6 Root 

846 Template 
1,4 92 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\core\repository\mem 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04: 41p 
04:41p 
04:41p 
6 



<DIR> 
<DIR> 
<DIR> 



File (s) 



CVS 

381 Makefile 
7,591 MemStoreDB. java 
14,777 MemSt ore. java 
22,749 bytes 
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test 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
ra\core\repository\mem\CVS \java\uei\espeaK\m 



fra N 

12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File (s) 



150 Entries 
73 Repository 
4 6 Root 
84 6 Template 
1,115 bytes 



Directory of E:\e-speak-src 991217\platform\ES\ 
fra\core\resource 



src\java\net\espeak\in 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/06/00 
C12/07/99 
H&2/07/99 
"12/07/99 
!3i2/07/99 
•J12/07/99 
;|2/07/99 
^2/07/99 
12/07/99 



04:33p 
04:33p 
04:41p 
04:41p 
04:33p 
04:41p 
04:41p 
04:41p 
04:41p 
04:41p 
04:41p 
04:41p 
04 : 41p 

13 File(s) 



<DIR> 
<DIR> 



<DIR> 



18,587 AbstractResource. java 
23, 240 CoreManagement Service. java 
CVS 

15,970 ESUIDFactory. java 
6,218 ExternalResource. java 
576 Makefile 

59,946 MetaResource. java 
2,800 MutableResourcelF. java 

14,087 ResourceType. java 

12, 611 ResourceSpecification. java 

17,749 ResourceFactory. java 

171,784 bytes 



S2/06/00 
l'2/06/OO 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File (s) 



568 
67 
46 

846 



Entries 

Repository 

Root 

Template 



1,527 bytes 



f ra 

12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:41p 
04:41p 



<DIR> 
<DIR> 
<DIR> 



CVS 

369 Makefile 
2,282 Response. java 
Page 57 



test 

12/07/99 04:41p 17,060 Router. java 

6 File(s) 19,711 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\core\router\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:20p 146 Entries 

12/16/99 06:20p 65 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

6 File(s) 1,103 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\core\security 



12/06/00 


04 


:33p 


<DIR> 






12/06/00 


04 


:33p 


<DIR> 






©2/06/00 


04 


:33p 


<DIR> 




CVS 


€2/07/99 


04 


:41p 




1,824 


Key IF. java 


12/07/99 


04 


:41p 




10, 631 


KeyRing . j ava 


$2/07/99 


04 


:41p 




7,550 


Key. java 


:%2/07/99 


04 


:41p 




456 


Makefile 


12/07/99 


04 


:41p 




24,731 


MD5 .java 


: l2/07/99 


04 


: 41p 




9, 913 


SecurityContext Factory 


: l'2/07/99 


04 


:41p 




3,095 


SecurityContext . java 



; = - 10 File(s) 58,200 bytes 

^Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
;s|ra\core\security\CVS 

|f2/06/00 04:33p <DIR> 
ife/06/00 04:33p <DIR> 

12/16/99 06:20p 355 Entries 

12/16/99 06:20p 67 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

6 File(s) 1,314 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\core\startup 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:41p 12,653 CoreArgs . j ava 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:41p 414 Makefile 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:41p 
04:41p 
04:41p 
04:41p 

9 File(s) 



test 

2,166 pingServer . real 
5,724 Server. java 
6,003 StartESCore. java 
35,876 StartupCore. java 
62,836 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\in 
f ra\core\startup\CVS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:20p 304 Entries 

12/16/99 06:20p 66 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

6 File(s) 1,262 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\core\sysmon 

!f 2/06/00 04:33p <DIR> 

,1^2/06/00 04:33p <DIR> 

$2/06/00 04:33p <DIR> CVS 

.12/07/99 04:41p 357 Makefile 

^2/07/99 04:41p 8,817 SystemMonitor . j ava 

; 5 ; 5 File{s) 9,174 bytes 

[.Directory of E : \e-speak-src_991217 \platf orm\ES\src\ j ava\net\espeak\in 
;Era\core\sysmon\CVS 

32/06/00 04:33p <DIR> 
#2/06/00 04:33p <DIR> 

lfe/16/99 06:20p 103 Entries 

1^/16/99 06:20p 65 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

6 File(s) 1,060 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\core\util 



12/06/00 


04 


:33p 


<DIR> 








12/06/00 


04 


:33p 


<DIR> 








12/07/99 


04 


:41p 




24, 


650 


CoreHelper . j ava 


12/06/00 


04 


:33p 


<DIR> 






CVS 


12/07/99 


04 


:41p 




35, 


464 


Logger. java 


12/07/99 


04 


:41p 






395 


Makefile 


12/07/99 


04 


:41p 




7, 


463 


ServiceRegistry 
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7 File(s) 



test 

67,972 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
fra\core\util\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File(s) 



205 Entries 
63 Repository 
46 Root 

846 Template 
1,160 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
f ra\core\vocabulary 



12/06/00 
12/06/00 
_12/06/00 
$2/07/99 
^2/07/99 
"12/07/99 
!2f2/07/99 
'12/07/99 
^2/07/99 
;l2/07/99 
"12/07/99 



04:33p 
04:33p 
04:33p 
04:41p 
04:41p 
04:41p 
04:41p 
04:41p 
04:41p 
04:41p 
04:41p 
11 



<DIR> 
<DIR> 
<DIR> 



File(s) 



CVS 

24,331 Expression. java 
3,717 ExprNode. java 
9,836 LiteralNode. java 
480 Makefile 

19,310 OpNode.java 
5,454 PropertyNode . java 

17,130 Tokenizer . java 

16,969 Vocabulary . java 
97,227 bytes 



^Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
.^ra\core\vocabulary\CVS 

K2/06/00 04:33p <DIR> 
¥2/06/00 04:33p <DIR> 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



File (s) 



408 Entries 
69 Repository 
4 6 Root 
84 6 Template 
1,369 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:20p 
06:19p 



<DIR> 
<DIR> 



48 Entries 

78 Entries. Log 

53 Repository 
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12/16/99 06:19p 
12/16/99 06:19p 

7 File(s) 



test 

4 6 Root 
846 Template 
1,071 bytes 



Directory of E : \e-speak-src_9 91217 \plat f orm\ES\src\ j ava\net\espeak\in 



f ra\intercorecom 






12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 


conf actory 


12/06/00 


04:33p 


<DIR> 


connectors 


12/06/00 


04:33p 


<DIR> 


CVS 


12/06/00 


04:33p 


<DIR> 


esip 


12/07/99 


04:26p 




303 Makefile 


12/06/00 


04:33p 


<DIR> 


proxy 


12/06/00 


04:33p 


<DIR> 


stacks 


12/06/00 


04:33p 


<DIR> 


util 




10 


File (s) 


303 bytes 



•4f Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
''*f ra\intercorecom\conf actory 



32/06/00 
LS2/06/00 
; fl2/07/99 

«L2/07/99 
12/06/00 

12/07/99 
fjiva 

J2/07/99 
:3f2/07/99 
$2/07/99 
: 3f2/07/99 
T2/07/99 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/06/00 
12/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:33p 
04:26p 

04:26p 
04:26p 
04 :26p 
04:26p 
04:26p 
04 :26p 
04:26p 
04:33p 
04 :26p 
04:33p 
04:26p 

17 File(s) 



<DIR> 
<DIR> 



<DIR> 



<DIR> 



<DIR> 



7,252 CFEvent Publisher . java 
6,288 CFStatistics. java 
co 

2, 138 CommunicationManagerException. j 

65,437 CommunicationManager . java 
7,656 ConnectionRegistry . java 
3,671 ConnectionEntry . java 
3,309 ConnFactoryTags . java 
6,409 ConnFactorySM. java 
4,682 ConnFactorylnf o. java 
2,133 CreateProxyExcept ion. java 
CVS 

502 Makefile 
policy 
3,523 Stat sUpdate . java 
113,000 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\ java\net\espeak\in 
f ra\intercorecom\conf actory\co 



12/06/00 04:33p 
12/06/00 04:33p 
12/07/99 04:26p 



<DIR> 
<DIR> 



6,484 Connect ionObject . java 



Page 61 



12/07/99 
12/06/00 
12/07/99 
12/07/99 



04:26p 
04:33p 
04:26p 
04:26p 
7 



test 

2,892 Connectionlnf olntf . java 
<DIR> CVS 

2, 515 SerializationException. java 
5,225 TCPConnectionlnf o . j ava 
File(s) 17,116 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
f ra\intercorecom\conf actory\co\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File (s) 



244 Entries 
80 Repository 
46 Root 

84 6 Template 
1,216 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
f ra\intercorecom\conf actory\CVS 



42/06/00 
M2/06/00 
$2/16/99 

il2/16/99 
•12/16/99 
^12/16/99 
; l2/16/99 



04:33p 
04 : 33p 
06:20p 
06:20p 
06:20p 
06:20p 
06:20p 
7 



<DIR> 
<DIR> 



File (s) 



694 Entries 
28 Entries. Log 
77 Repository 
46 Root 

846 Template 
1,691 bytes 



^•Directory of E: \e-speak-src_991217\platf orrn\ES\src\ java\net\espeak\in 
jjra \ inter core com\conf act ory\pol icy 



! l:2/0 6/00 


04 


: 33p 


<DIR> 








§2/06/00 


04 


:33p 


<DIR> 








12/06/00 


04 


:33p 


<DIR> 






CVS 


12/07/99 


04 


: 26p 




13, 


446 


Negotiator . j ava 


12/07/99 


04 


:26p 




14, 


105 


NegotiationPolicy . java 


12/07/99 


04 


:26p 




4, 


684 


NegotiationOf fer . java 


12/07/99 


04 


:26p 




2, 


348 


NegotiationFailedException 


12/07/99 


04 


:26p 




3, 


337 


SecurityPolicy . java 



8 File(s) 



37,920 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\intercorecom\conf actory\policy\CVS 



12/06/00 04:33p 
12/06/00 04:33p 
12/16/99 06:20p 



<DIR> 
<DIR> 



296 Entries 
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test 

12/16/99 06:20p 84 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

6 File(s) 1,272 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
f ra\intercorecom\connectors 



12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 






12/07/99 


04 


:26p 




7,732 


ConnectorManager . j ava 


12/07/99 


04 


:26p 




6,183 


ConnectorDesc . j ava 


12/07/99 


04 


:26p 




4,495 


Connector . j ava 


12/06/00 


04 


:33p 


<DIR> 




CVS 


12/07/99 


04 


:26p 




5,514 


DataConnector . j ava 


12/07/99 


04 


:26p 




3,714 


ListeningConnector . java 


12/07/99 


04 


:26p 




557 


Makefile 


12/07/99 


04 


:26p 




13,703 


TcpDataConnector . j ava 


12/07/99 


04 


:26p 




7,334 


TcpListeningConnector . j ava 


A2/07/99 


04 


:26p 




6,420 


TcpTunnelConnector . j ava 






12 


File(s) 


55,652 bytes 



^Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
;"Mra\ inter cor ecom\connectors\CVS 



^2/06/00 
it2/06/00 
; 12/16/99 
12/16/99 
'52/16/99 
! l2/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File(s) 



508 Entries 
77 Repository 
4 6 Root 

84 6 Template 
1,477 bytes 



^Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net \espeak\in 
f ra\intercorecom\CVS 



12/06/00 


04:33p 


<DIR> 






12/06/00 


04:33p 


<DIR> 






12/16/99 


06:20p 




48 


Entries 


12/16/99 


06:20p 




99 


Entries . Log 


12/16/99 


06:20p 




66 


Repository 


12/16/99 


06:20p 




46 


Root 


12/16/99 


06:20p 




846 


Template 



7 File(s) 1,105 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\intercorecom\esip 
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test 



12/06/00 04:33p < D IR> 
12/06/00 04:33p <DIR> 

12/06/00 04:33p < D IR> r^c 

12/07/99 04:26p o S4 o . 1M 

12/07/99 04:26p ' ESIPControlMessage . 3 ava 

12/07/99 04:26p l']*] ^PExportMessage . j ava 

12/07/99 04:26p i'lfl HjIT ^'^^ 

12/07/99 04:26p t l?l F^pfT^ ^ 

lo/nR/QQ n , 2,126 ESIPPayload.java 

12/08/99 03:16p 461 Makefile 

9 Fxle(s) 20,252 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 

fra\intercorecom\esip\CVS \espeaK\m 

12/06/00 04:33p <DIR> 
12/06/00 04:33p < D IR> 

12/16/99 06:20p o 9s ^^ ao 

12/16/99 06:20p 3 ?? p^ 1 ^ 

^2/16/99 06:20^ Roo't 

J2/16/99 06:20 P 846 Opiate 

Si 6 File(s) 1,288 bytes 

92/06/00 04:33p < D IR> 
T2/06/00 04:33p < D IR> 

3,2/06/00 04:33p < D IR> CVS 

i/07/99 04: 2 2 | 2 ''" f^rrayOutputStrearo.java 

8™» 2 : SS£S£^«- 

12/07/99 04:26p J' 7°* ^V^portHandler . java 

12/07/99 04:26p of' J' 9 ^m 3 ™ 

12/07/99 04:26p ^'lll f' 3 *™ 

^ J,««2 Timeouts . iava 

12 File(s) 128,144 bytes 

12/06/00 04:33p < D IR> 

12/06/00 04:33p < D IR> 

12/16/99 06:20p 4 o Q ;* . 

12/16/99 06:20p ^ * ntr ^ 

12/16/99 06:20p J^Repos xtory 

12/16/99 06 = 20p 846 Opiate 
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6 File(s) 



test 
1,453 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
fra\intercorecom\ stacks 



12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/07/99 


04 


:26p 




5, 443 


LayerFactory . j ava 


12/06/00 


04 


:33p 


<DIR> 




layers 


12/07/99 


04 


:26p 




457 


Makefile 


12/07/99 


04 


:26p 




4, 429 


StackBuilder . j ava 


12/07/99 


04 


:26p 




14,775 


Stack. java 






8 


File(s) 


25,104 


\ bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
f ra\intercorecom\stacks\CVS 



_.12/06/00 
$12/06/00 
%2/16/99 
*'*L2/16/99 

ii.2/16/99 
IB.2/16/99 
:fl2/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
06:20p 
7 



<DIR> 
<DIR> 



File(s) 



203 Entries 
16 Entries. Log 
73 Repository 
46 Root 

846 Template 
1,184 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
^fra\intercorecom\stacks\ layers 



£3.2/06/00 

212/ 06/ 00 
3.2/07/99 
i!K i2/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04 :33p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
9 



<DIR> 
<DIR> 

<DIR> 



File (s) 



2,166 CILayer.java 
CVS 

3,461 Layerlntf . java 
4,834 Layer. java 

4 64 Makefile 
7, 071 NaraeAuthenticationLayer . java 
2,221 TransportLayer . java 
20,217 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
fra\intercorecom\stacks\ layers \CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:20p 316 Entries 

12/16/99 06:20p 80 Repository 
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12/16/99 
12/16/99 



06:20p 
06:20p 

6 File(s; 



test 

4 6 Root 
846 Template 
1,288 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\intercorecom\util 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:26p 
04:2 6p 
04:33p 
04:2 6p 
04:26p 
04:26p 
04:26p 
04:26p 
10 



<DIR> 
<DIR> 



<DIR> 



File(s) 



3,820 CondVar.java 

7, 348 Connect ionObjectFileReader . java 
CVS 

4,748 Header. java 
3,180 Lock. java 

439 Makefile 
3,27 6 Synchronizer. java 
3,090 Verif yDomain. java 
25,901 bytes 



?f Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
If ra\intercorecom\util\CVS 



L 42/06/00 
r t2/06/00 
E2/16/99 
r t2/16/99 
12/16/99 
"12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 



<DIR> 
<DIR> 



6 File(s; 



367 Entries 
71 Repository 
4 6 Root 
84 6 Template 
1,330 bytes 



^Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
:f ra\xrr.l 



: f'2/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/07/99 


04 


:26p 




2, 931 


ESXMLDecoder Intf . j ava 


12/07/99 


04 


:26p 




49,369 


ESXMLDecoder . j ava 


12/07/99 


04 


:26p 




2,453 


ESXMLEncoder Intf . j ava 


12/07/99 


04 


:26p 




6,183 


ESXMLEncoder . j ava 


12/07/99 


04 


:26p 




2,761 


ESXMLShelllntf . j ava 


12/07/99 


04 


:26p 




20, 001 


ESXMLShell. java 


12/06/00 


04 


:33p 


<DIR> 




IE5 


12/07/99 


04 


:26p 




515 


Makefile 


12/06/00 


04 


: 33p 


<DIR> 




s enemas 


12/07/99 


04 


:26p 




7,355 


XML App. java 


12/07/99 


04 


:26p 




4,425 


XMLNameList .java 


12/06/00 


04 


:33p 


<DIR> 




xmlserver 
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15 File(s) 



test 

95,993 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
fra\xml\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
06:20p 

7 File(sl 



<DIR> 
<DIR> 



481 Entries 
4 9 Entries. Log 
57 Repository 
4 6 Root 

846 Template 
1,479 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
fra\xml\IE5 



12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 






33.2/06/00 


04 


: 33p 


<DIR> 




CVS 


112/07/99 


04 


:26p 




854 


e-speak_logo 


42/07/99 


04 


: 26p 




1, 7 92 


lookup.htm 


M12/07/99 


04 


:26p 




3,320 


lookup. js 


.112/07/99 


04 


:26p 




628 


Readme . txt 


i3l2/07/99 


04 


:26p 




1, 623 


register.htm 


112/07/99 


04 


:26p 




3,226 


register. js 


"12/07/99 


04 


:26p 




3, 631 


response . j s 


-12/07/99 


04 


:26p 




1,757 


vocab. htm 


"12/07/99 


04 


: 26p 




3, 873 


vocab . j s 






12 


File (s) 


20,704 


[ bytes 



^Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net \espeak\in 
j lra\xml\IE5\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File (s) 



432 Entries 
61 Repository 
4 6 Root 

846 Template 
1,385 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\xml\ schema s 



12/06/00 04:33p 
12/06/00 04:33p 
12/06/00 04:33p 



<DIR> 
<DIR> 
<DIR> 



CVS 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
8 



File(s) 



test 

4,405 es-basic.xsd 

368 es-lookup.xsd 

419 es-register .xsd 

589 es-response . xsd 

4 98 es-vocab.xsd 
6,279 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\xml\schemas\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 

6 File(s) 



<DIR> 
<DIR> 



255 Entries 
65 Repository 
4 6 Root 

84 6 Template 
1,212 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 



SEr a \ xml \xmlserver 






ML2/06/00 


04:33p 


<DIR> 




UI2/06/00 


04:33p 


<DIR> 




IU2/06/00 


04:33p 


<DIR> 


CVS 


'112/07/99 


04 :26p 




5,291 ESXMLHttp. java 


1112/07/99 


04:26p 




3,218 ESXMLServerThread. java 


1=12/07/99 


04:26p 




3,397 ESXMLServer. java 


=•12/07/99 


04 :26p 




314 Makefile 


H.2/07/99 


04:26p 




8,305 Test ServerApp. java 




8 File(s) 




20, 525 bytes 


4f Directory of E:\e-speak-src 


991217\platform\ES\src\java\netY 


■<£ r a \ xml \ xml s e r v e r \ CV S 




12/06/00 


04: 33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/16/99 


06:20p 




266 Entries 


12/16/99 


06:20p 




67 Repository 


12/16/99 


06:20p 




4 6 Root 


12/16/99 


06:20p 




846 Template 




6 File(s) 




1,225 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net \espeak\ je 
si 



12/06/00 04:33p 
12/06/00 04:33p 
12/07/99 04:26p 



<DIR> 
<DIR> 



7,741 AppSessionlDFilter . java 
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test 



12/07/99 


04: 


26p 


9, 


404 


12/07/99 


04: 


26p 


9, 


098 


12/06/00 


04. 


33p 


<DIR> 




12/07/99 


04: 


26p 


3, 


496 


12/07/99 


04: 


26p 


55, 


605 


12/07/99 


04: 


26p 


38, 


691 


12/07/99 


04: 


26p 


8, 


783 


12/07/99 


04: 


26p 


47, 


370 


12/07/99 


04- 


26p 


2, 


293 


12/07/99 


04. 


26p 


17, 


372 


12/07/99 


04: 


2 6p 


4, 


455 


12/07/99 


04 


26p 


3, 


690 


12/07/99 


04 


2 6p 


9, 


610 


12/07/99 


04 


:26p 


17, 


621 


12/07/99 


04 


26p 


2, 


226 


12/07/99 


04 


:26p 


9, 


288 


12/07/99 


04 


:26p 


22, 


360 


12/07/99 


04 


:26p 


7, 


475 


12/07/99 


04 


:26p 


5, 


151 


132/07/99 


04 


:26p 


2, 


374 


02/07/99 


04 


:26p 


4, 


939 


'12/07/99 


04 


:26p 


7 , 


132 


IJ2/07/99 


04 


:26p 


2, 


478 


112/07/99 


04 


:26p 


12, 


.068 


$2/07/99 


04 


:26p 


11, 


751 


112/07/99 


04 


:26p 


18, 


190 


42/C7/99 


04 


:26p 


47, 


.841 


-12/07/99 


04 


:26p 


6, 


580 


f2/07/99 


04 


:26p 


8, 


475 


$2/07/99 


04 


:26p 


6, 


.541 


•512/07/99 


04 


:26p 


7, 


. 474 


'$2/07/99 


04 


:26p 


7, 


, 914 


®2/07/99 


04 


: 26p 


44, 


. 996 


lfe/07/99 


04 


:26p 


12, 


.517 


12/07/99 


04 


:26p 


6, 


,168 


12/07/99 


04 


:26p 


55, 


, 878 


12/07/99 


04 


:26p 


3 


,806 


12/07/99 


04 


:26p 


6, 


, 331 


12/07/99 


04 


:26p 


5, 


,295 


12/07/99 


04 


:26p 


2, 


,228 


12/07/99 


04 


:26p 


5, 


, 026 


12/07/99 


04 


:26p 


9 


, 790 


12/07/99 


04 


:26p 


1, 


, 977 


12/07/99 


04 


:26p 


2, 


, 633 


12/07/99 


04 


:26p 


4 


, 917 


12/07/99 


04 


:26p 


14 


, 917 


12/07/99 


04 


:26p 


2, 


, 388 


12/07/99 


04 


:2 6p 


3 


, 755 



ClassDependencyFinder . java 

ClassFinder .java 

CVS 

ESContract . j ava 
ESAbstract Finder . j ava 
ESAbstractElement . j ava 
ESAccessRight . j ava 
ESAccessorStub . j ava 
ESAccessorHandle . j ava 
ESAccessor . j ava 
ESAppSessionlD. java 
ESAssert . java 
ESAttr ibute . j ava 
ESBaseServiceStub. java 
ESBaseService . j ava 
ESBaseQuery . java 
ESBaseDescription. java 
ESServiceDescription . j ava 
ESVocabularyElement . j ava 
ESService. java 
ESCallbacklntf . j ava 
ESCallbacklmpl . j ava 
ESCloneable. java 
ESCommunity . j ava 
ESConf iguration. java 
ESConnector . j ava 
ESConnect ion . j ava 
ESConstants . java 
ESContractStub . j ava 
ESContractFinder . j ava 
ESContractElement . j ava 
ESContract Description . java 
ESServiceElement . java 
ESServiceContext . j ava 
ESFolderFinder . j ava 
ESFolder . java 
ESHashMap. java 
ESHelper . java 
ESImplProxy . j ava 
ES Introspect ion Int f . java 
ESIntrospectionlmpl .java 
ESList .java 
ESManagementlntf . java 
ESMessageRegistrylntf .java 
ESMessage . j ava 
ESMPM. java 
ESNaitie Factory . j ava 
ESQuery.java 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
J2/07/99 
^2/07/99 
M2/07/99 
12/06/00 
32/07/99 
^2/07/99 
#2/06/00 



04:26p 

04:26p 

04:26p 

04 :26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:33p 

04:26p 

04:26p 

04:33p 

76 File(s) 



<DIR> 



<DIR> 



test 

3,189 ESRunnable. java 
13,633 ESScope.java 

2,564 ESSecuritylntf . java 

8,64 9 ESServiceStub. java 
18,986 ESServiceMessenger . java 
21,090 ESServiceHandler. java 

8,170 ESServiceFinder . java 

2,507 ESSessionlntf . java 

4,693 ESSessionlmpl. java 
18,154 ESStartService. java 

2,223 ESStubFactorylntf . java 

6.867 ESStubFactorylmpl. java 
4,213 ESThread. java 

4,909 ESUniqList. java 
6,042 ESUserCredential. java 
20, 618 ESVocabularyDescript ion. java 

2.868 ESVocabulary . java 
8,682 ESVocabularyStub. java 
6,647 ESVocabularyFinder . java 
3,243 ESXMLFile. java 

5,276 ESXMLQuery. java 
event 

5,290 GenericClassLoader . java 
2,169 Makefile 

management 
788,790 bytes 



^Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\ j 



12/06/00 

;i;2/o6/oo 

12/16/99 
1*2/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
06:20p 
7 



<DIR> 
<DIR> 



File(s) 



3, 944 
35 
52 
46 
846 
4, 923 



Entries 
Entries . Log 
Repository 
Root 

Template 
bytes 



Directory of 
si\event 



:\e-speak-src_991217\platform\ES\src\java\net\espeak\j 



12/06/00 
12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:33p 
04 :26p 
04:2 6p 



<DIR> 
<DIR> 
<DIR> 
<DIR> 



coredist 
CVS 

15,259 ESCoreSubscriber. java 

2,359 ESCoreListenerlntf . java 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 



04: 
04: 
04: 
04: 
04: 
04: 
04: 
04: 
04: 
04 : 
04: 
04: 
04: 
04: 
04: 



2 6p 
26p 
26p 
26p 
26p 
26p 
26p 
26p 
33p 
33p 
26p 
26p 
26p 
26p 
33p 
21 



<DIR> 
<DIR> 



<DIR> 



File (S) 



test 
14,426 
6,481 
2, 777 
5, 660 
2,589 
20,502 
17,999 
2,059 



730 
5,740 
4,843 
5,769 

107,193 



ESDistributor . j ava 
ESListenerStub . j ava 
ESListenerlntf . j ava 
ESPublisherStub . j ava 
ESPublisherlnt f . j ava 
ESPublisher. java 
ESSubscriber . j ava 
EventException . j ava 
impl 
intf 

Makefile 

Publisher Info . j ava 
ResultSetEntry. java 
ResultSet . java 
util 
bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\j 
,*si\ event \coredist 



C12/ 

a 2/ 

%2/ 
,42/ 

a 2/ 
;:i2/ 

'.12/ 
.12/ 
111 2/ 



06/00 
06/00 
07/99 
06/00 
07/99 
07/99 
07/99 
07/99 
07/99 



04:33p 
04:33p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 



<DIR> 
<DIR> 

<DIR> 



9 File(s; 



6,908 CoreSubProfile. java 
CVS 

3,621 ESCoreListenerStub. java 
4,352 ESCoreDistributorStub. java 
3,343 ESCoreDistributorlntf . java 
8,886 ESCoreDistributorlrapl. java 

485 Makefile 
27,595 bytes 



;| Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\ j 
fk i\event\coredist\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File (s) 



353 Entries 
67 Repository 
4 6 Root 

846 Template 
1,312 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net \espeak\ j 
si\event\CVS 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:20p 772 Entries 
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12/16/99 06:20p 60 Entries. Log 

12/16/99 06:20p 58 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

7 File(s) 1,782 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\je 
si\event\impl 

<DIR> 
<DIR> 

<DIR> CVS 

11,967 DistributorStore. java 
10, 316 ESEventServiceComponentHelper. j 

17,224 ESEventServiceComponent . j ava 
12,805 ESEvent Distributorlmpl . j ava 
510 Makefile 
5,724 RegisterEventABI . java 
4,909 SubsDet.java 
Q 10 File(s) 63,455 bytes 

:il Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\je 
;^i\event\impl\CVS 

J^.2/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

^2/16/99 06:20p 413 Entries 

142/16/99 06:20p 63 Repository 

142/16/99 06:20p 46 Root 

|2/16/99 06:20p 846 Template 

iji 6 File(s) 1,368 bytes 

'"Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net \espeak\ j e 
si\event\intf 



CVS 



12/06/00 


04 


:33p 


12/06/00 


04 


: 33p 


12/06/00 


04 


: 33p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


ava 






12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


^2/07/99 


04 


:26p 


y.2/07/99 


04 


:26p 



12/06/00 


04:33p 


<DIR> 






12/06/00 


04:33p 


<DIR> 






12/06/00 


04:33p 


<DIR> 






12/07/99 


04:26p 




10, 


752 


12/07/99 


04:26p 




3, 


317 


y . j ava 










12/07/99 


04:26p 




4, 


324 


12/07/99 


04 :2 6p 




11, 


792 


12/07/99 


04:26p 




3, 


320 


ry . java 










12/07/99 


04 :26p 




2, 


865 


12/07/99 


04:26p 




4, 


945 
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test 



ava 

12/07/99 04:26p 
j ava 

12/07/99 04:26p 

12 File(s) 



3, 346 ESPublisherlntfMessageRegistry . 

613 Makefile 
45,274 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\ je 
si\event\intf \CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04 :33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 



<DIR> 
<DIR> 



6 File(sl 



578 Entries 
63 Repository 
4 6 Root 

846 Template 
1,533 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\je 

ffi\event\util 



'3.2/06/00 
j.2/06/00 
^12/07/99 
112/06/00 
i|l2/07/99 
W12/07/99 
,12/07/99 
1*12/07/99 
jll2/07/99 
&2/07/99 
112/07/99 
512/07/99 
: ; iL2/07/99 
"12/07/99 



04: 

04: 

04: 

04: 

04: 

04: 

04: 

04: 

04: 

04: 

04 : 

04 

04 

04 



33p 
33p 
26p 
33p 
26p 
26p 
26p 
26p 
26p 
26p 
26p 
2 6p 
26p 
26p 
14 



<DIR> 
<DIR> 

<DIR> 



File (s) 



4,686 CoreEvent Predicate . j ava 
CVS 

5,530 EventContext. java 
3,783 Event Dat aTypes . java 
8,7 88 EventMapEntry . java 
8,550 EventMap . j ava 
8,253 EventPredicate . java 
5,526 Id. java 
6,323 Inputlnfo. java 

551 Makefile 
6,391 PubProfile. java 
9,576 SubProfile. java 
67,957 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\ j 
si\event\util\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 



<DIR> 
<DIR> 



6 File(s; 



578 Entries 
63 Repository 
4 6 Root 

846 Template 
1, 533 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\ j 
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si\management 



test 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
ry . j ava 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
,12/07/99 
12/07/99 
1*12/07/99 
."$2/07/99 
512/07/99 
'^2/07/99 
512/07/99 
: '12/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 

04 :26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
23 



<DIR> 
<DIR> 



<DIR> 



File (s) 



12, 092 AbstractManagedService . j ava 
2, 703 CoreConnectionException. java 
CVS 

2, 672 IllegalStateTransition.esidl 

2, 415 IllegalStateTransition. java 

1,135 Makefile 
12,8 99 ManagedServicelntf .esidl 
15,798 ManagedServiceStub. java 

2, 306 ManagedServicelntf MessageRegist 

12,899 ManagedServicelntf . java 
3,4 96 ManageableService . java 
2,680 NoSuchVariableName. esidl 
2,395 NoSuchVariableName. java 
1,748 ResourceEntry. esidl 
2,800 ResourceEntry. java 
6,580 ServiceContext . java 

6.096 SimpleManagedService . java 
1,770 VariableType. esidl 

3.097 VariableType. java 
1,965 VariableEntry. esidl 
2,734 VariableEntry . java 

100,280 bytes 



j'lj Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\je 
i \manageraent \ CVS 



; 5l2/06/00 
312/06/00 
"12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



1,191 
63 
46 
846 



File (s) 



Entries 

Repository 

Root 

Template 



2,146 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\se 
rvices 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/06/00 
12/06/00 



04:33p 
04:33p 
04:33p 
04:26p 
04:33p 
04:33p 



<DIR> 
<DIR> 
<DIR> 

<DIR> 
<DIR> 



advertise 
14 9 compile.bat 
CVS 

events 
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12/07/99 


04: 


26p 




12/06/00 


04 : 


33p 


<DIR> 


12/06/00 


04 : 


33p 


<DIR> 






9 


File (s) 


Directory of 


E : \e-speak-src 


rvices\advertise 




12/06/00 


04 : 


33p 


<DIR> 


12/06/00 


04 : 


33p 


<DIR> 


12/06/00 


04 : 


33p 


<DIR> 


12/06/00 


04 : 


J3p 


<DIR> 


12/06/00 


04 : 


33p 


<DIR> 


12/07/99 


04: 


26p 




12/07/99 


04: 


26p 




12/06/00 


04: 


33p 


<DIR> 


12/06/00 


04: 


33p 


<DIR> 


12/06/00 


04: 


33p 


<DIR> 


,-,12/07/99 


04 : 


26p 




Sl2/07/99 


04: 


26p 




Cil2/07/99 


04: 


26p 




■j§12/06/00 


04: 


33p 


<DIR> 


!l!l2/06/00 


04: 


33p 


<DIR> 


30.2/06/00 


04: 


33p 


<DIR> 


1:12/06/00 


04: 


33p 


<DIR> 






17 


File (s) 



test 

269 Makefile 
management 
tunnel 
418 bytes 



agents 
bin 

clientapi 
1,055 compile.bat 
143 co.MYCOs 
CVS 

discovery 
exception 
325 Makefile 
668 makefile. release 
131 object-class-definition 
query_parser 
util 

ypcommon 
ypserver 
2,322 bytes 

!=*■, Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
f!jrvices\advertise\agents 



3112/06/00 
512/06/00 
012/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04 : 33p 
04:26p 
04:26p 
04:26p 

8 File(s) 



<DIR> 
<DIR> 



<DIR> 



14,434 AdvLSAgent . java 
5,019 BackendAgentlntf . java 
CVS 

45,917 LDAPDirAgent . java 
441 Makefile 
6,372 ProxySocketFactory . java 
72,183 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\se 
rvices\advertise\agents\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 



04: 33p 
04:33p 
06:20p 
06:20p 
06:20p 



<DIR> 
<DIR> 



272 Entries 
73 Repository 
4 6 Root 
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12/16/99 06:20p 

6 File(s; 



test 

846 Template 
1,237 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\se 
rvices\advertise\bin 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
,42/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 

13 File(s) 



<DIR> 
<DIR> 
<DIR> 



CVS 

607 runas_ldap.bat 
640 runas_ldap 
599 runas_noldap 
580 runas_noldap.bat 
585 runas_ldap_s 
549 runas_ldap_s.bat 
585 runas_ldap_i_s 
549 runas_ldap_i_s . bat 
673 runas_ldap_i 
635 runas_ldap_i.bat 
6,002 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\se 
!2tvices\advertise\bin\CVS 



#2/06/00 

i'l2/06/00 
'12/16/99 
"12/16/99 
'42/16/99 
:4 = 2/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File (s) 



513 Entries 
7 0 Repository 
46 Root 

84 6 Template 
1,475 bytes 



■^Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\advertise\clientapi 



12/06/00 04:33p 
12/06/00 04:33p 
12/06/00 04:33p 
12/07/99 04:26p 
12/07/99 04:26p 

5 File(s] 



<DIR> 
<DIR> 
<DIR> 



CVS 

23,009 ESADServicelnterface. java 
37 6 Makefile 
23,385 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\se 
rvices\advertise\clientapi\CVS 



12/06/00 04:33p 
12/06/00 04:33p 
12/16/99 06:21p 



<DIR> 
<DIR> 



110 Entries 



Page 7 6 



12/16/99 06:20p 76 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

6 File(s) 1,078 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\advertise\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:20p 254 Entries 

12/16/99 06:21p 158 Entries. Log 

12/16/99 06:20p 66 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

7 File(s) 1,370 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\se 
;=Si rvices\advertise\discovery 

JJL2/06/00 04:33p <DIR> 

; 12/06/00 04:33p <DIR> !. 

^f.2/07/99 04:26p 4,005 AdvDscvMsgBag . j ava 

^2/07/99 04:26p 1, 992 AdvDscvMsg. j ava 

,#2/07/99 04:26p 4,022 AdvIncomingDscvRqst . java 

J.2/07/99 04:26p 4,575 AdvIncomingDscvRply . java 

, 12/07/99 04:26p 12,183 AdvMcastSenderReceiver . java 

1.3-2/07/99 04:26p 3,810 AdvOutgoingDscvRqst . j ava 

1*12/07/99 04:26p 7,247 AdvOutgoingDscvRply . java 

,42/07/99 04:26p 4,524 AdvSLPOutgoingMsg . j ava 

,42/07/99 04:26p 3,336 AdvSLPMsg. java 

42/07/99 04:26p 7,123 AdvSLPIncomingMsg. java 

42/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 640 Makefile 

14 File(s) 53,457 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\advertise\discovery\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:21p 632 Entries 

12/16/99 06:21p 76 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

6 File(s) 1,600 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\se 
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rvices\ advert ise\except ion 



test 



12/06/00 


04 


:33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/07/99 


04 


: 26p 




3,118 


12/07/99 


04 


:26p 




3,237 


12/06/00 


04 


: 33p 


<DIR> 


12/07/99 


04 


:26p 




3,089 


12/07/99 


04 


:26p 




490 


12/07/99 


04 


:26p 




3,175 


12/07/99 


04 


:26p 




3, 148 






9 


File (s) 


16,25' 



CVS 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\ 
rvices\advertise\exception\CVS 



se 



12/06/00 
12/06/00 
,=42/16/99 
;ii2/16/99 
&2/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



349 Entries 
7 6 Repository 
46 Root 

84 6 Template 
1,317 bytes 



rjj Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\se 
i„rvices\advertise\query parser 



U-2/06/00 
4.2/06/00 
42/06/00 
,§2/07/99 
42/07/99 
§2/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:2 6p 
04:26p 
04:26p 
04:26p 
04:26p 
04:2 6p 
04:26p 
04:26p 
04:26p 
04:26p 
04:2 6p 
04 :26p 



<DIR> 
<DIR> 
<DIR> 



CVS 

2,505 LDAPQueryOps. java 

747 Makefile 
3,408 QueryLeaf Node. java 
4,285 QueryAndNode. java 
5,451 QueryComparatorNode. java 
4,077 QueryExprNode. java 
3,667 QueryEqNode . java 
3,095 QueryGtNode. java 
3,101 QueryGeNode. java 
2,252 QueryldentifierNode. java 
3,073 QueryLtNode. java 
2,636 QueryLiteralNode . java 

17,430 QueryLex. java 
3,097 QueryLeNode. java 
3,4 98 QueryNotNode. java 
3,825 QueryNeqNode. java 
4,373 QueryOrNode. java 

14,678 QueryParser. java 
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21 File(s) 



test 

85,198 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\advertise\query_parser\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04: 33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



975 Entries 
79 Repository 
46 Root 
84 6 Template 
1,946 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\se 
rvices\advertise\util 



12/06/00 
12/06/00 
.42/06/00 

;iJl2/07/99 
"12/07/99 
12/07/99 
;ffL2/07/99 
412/07/99 



04:33p 
04 :33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 

8 File(s) 



<DIR> 
<DIR> 
<DIR> 



CVS 

3,428 eskill.java 

424 Makefile 
5,560 Multicaster . java 
2,191 Shutdownlntf . java 
6,600 ShutdownCtrl. java 
18,203 bytes 



I"' Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
; rvices\advertise\util\CVS 



*l2/06/00 04:33p 

112/06/00 04:33p 

42/16/99 06:21p 

?|2/16/99 06:21p 

12/16/99 06:21p 

12/16/99 06:21p 

6 File(s) 



<DIR> 
<DIR> 



257 Entries 
71 Repository 
4 6 Root 

84 6 Template 
1,220 bytes 



Directory of E : \e-speak-src_991217 \platf orm\ES\src\ j ava\net \espeak\se 
rvices\advertise\ypcommon 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:33p 
04:26p 
04 :26p 
04:26p 



<DIR> 
<DIR> 



<DIR> 



2,249 AdvDebug. java 
6,157 ArraySet. java 
CVS 

689 Makefile 
2,4 65 QueryOps . j ava 
2,537 YPCompBigDecimal . java 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:26p 
04:26p 
04 :26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04 :26p 
04:26p 
04:26p 
20 



File (s) 



test 

2,451 YPCompFloat . java 
9,801 YPComparator. java 
2,430 YPCompByte . j ava 
2,442 YPCompDouble . j ava 
2,566 YPComparable. java 
2,353 YPCompString. java 
2,4 30 YPCompShort . java 
2,418 YPCompLong. java 
2,439 YPCompInt. java 
2,504 YPCompChar. java 
2,087 YPObjects. java 
2,745 YPOperations . j ava 
50,763 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\se 
rvices\advertise\ypcommon\CVS 



12/06/00 
,,4.2/06/00 

.112/16/99 
^12/16/99 
.4.2/16/99 
^2/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File(s) 



890 Entries 
75 Repository 
46 Root 

846 Template 
1,857 bytes 



£ Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net \espeak\se 
,,rvices\advertise\ypserver 



1112/06/00 
1212/06/00 
A 2/07/99 
§2/07/99 
§2/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 

16 File(s) 



<DIR> 
<DIR> 



<DIR> 



88,292 AdvertisingService . j ava 
4,168 BackendLookupResult . java 
5,140 BackendConnectionlnfo. java 

16,210 ConnectionManager . java 
CVS 

4,733 ExternalEsrl . java 

651 Makefile 
4,138 TimeoutHandler . java 
5,346 YPGenericTable. java 
5,4 38 YPItemsTable. java 
4,980 YPItem.java 
3,221 YPMessage . java 
3,821 YPSearchResultsTable. java 
9,852 YPSearchResult . java 
155, 990 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\advertise\ypserver\CVS 
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test 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



728 Entries 
75 Repository 
46 Root 

84 6 Template 
1, 695 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\s 
rvices\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
42/16/99 



04:33p 
04:33p 
06:20p 
06:21p 
06:20p 
06:20p 
06:20p 
7 



<DIR> 
<DIR> 



File (s) 



96 Entries 
71 Entries. Log 
56 Repository 
46 Root 
846 Template 
1,115 bytes 



^Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\s 
ipvices\events 



12 
:.12 
=12 
,12 
rl2 
A2 

m 

•312 



/06/00 
/06/00 
/07/99 
/06/00 
/07/99 
/07/99 
/07/99 
/07/99 
/07/99 



04:33p 
04:33p 
04:2 6p 
04:33p 
04:2 6p 
04:26p 
04:2 6p 
04:26p 
04 :26p 
9 



<DIR> 
<DIR> 

<DIR> 



File(s) 



697 compile.bat 
CVS 

5,926 ESCoreDistributor . java 

5, 093 ESManagement Distributor. java 

3,995 ESServiceDistributor . java 

465 Makefile 

510 makefile . release 
16,686 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\s 
rvices\events\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



335 Entries 
63 Repository 
4 6 Root 

84 6 Template 
1,290 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\s 
rvices\management 
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test 



12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 






12/07/99 


04 


:26p 




1,328 


compile .bat 


12/06/00 


04 


: 33p 


<DIR> 




coremanager 


12/06/00 


04 


:33p 


<DIR> 




CVS 


12/06/00 


04 


:33p 


<DIR> 




logger 


12/07/99 


04 


:26p 




333 


Makefile 


12/07/99 


04 


: 26p 




759 


makefile . release 


12/06/00 


04 


: 33p 


<DIR> 




policymanager 


12/06/00 


04 


:33p 


<DIR> 




processmanager 


12/06/00 


04 


: 33p 


<DIR> 




servicemanager 


12/06/00 


04 


:33p 


<DIR> 




web 



12 File(s) 



2,420 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\ 
rvices\management\coremanager 



,42/06/00 
,12/06/00 
•32/07/99 
J2/07/99 
$2/07/99 
.;|2/07/99 
112/07/99 
142/07/99 
; ,12/07/99 
42/07/99 
12/07/99 
#2/07/99 
12/07/99 
32/06/00 
132/07/99 
12/07/99 
12/07/99 
12/07/99 
12/15/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:33p 
04:26p 
04:2 6p 
04:2 6p 
04:26p 
04:00p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 

27 File(s) 



<DIR> 
<DIR> 



<DIR> 



27,653 CoreManager . java 

20,917 CoreManagerMSIrapl. java 

12,661 CoreManagerOS . java 

19,588 CoreManagerMS. java 
705 compile.bat 
7,599 CoreEventSubscriberlmpl . j ava 
5,247 CoreEvent Subscriber . java 
7,420 CoreManagerTags . java 
6,473 CoreManagerStats . java 
4,484 CoreManagerOSIntf . java 

23,110 CoreManagerOSIrapl . java 
CVS 

4,148 DbgLog.java 

6,249 EventPublisher . java 

8,116 ExtEventSubscriberlmpl . java 

4,622 ExtEventSubscriber . java 
931 Makefile 
527 makefile . release 

5,151 ServiceDataList . java 

3,528 Shutdown. java 

5,112 StateMC. java 

4,434 Staticlnfo. java 
10,091 StatsReader. java 

3,785 StatsStore. java 

6,651 UpdateStats . java 
199,202 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\ 
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test 

rvices\management\coremanager\CVS 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:21p 1,324 Entries 

12/16/99 06:21p 79 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

6 File(s) 2,295 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
r vice s \management \CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:21p 149 Entries 

12/16/99 06:21p 121 Entries. Log 

12/16/99 06:21p 67 Repository 

-12/16/99 06:21p 46 Root 

112/16/99 06:21p 846 Template 

%! 7 File(s) 1,229 bytes 



f'll Directory of E:\e-speak-src 


991217\platform\ES\src\java\net\espeak\se 


}t:vices\management\ logger 


=12/06/00 


04:33p 


<DIR> 




„ 12/06/00 


04:33p 


<DIR> 




-12/06/00 


04 :33p 


<DIR> 


client 


•112/06/00 


04:33p 


<DIR> 


CVS 


'512/07/99 


04 :26p 




333 Makefile 


312/06/00 


04:33p 


<DIR> 


manager 


;:£2/06/00 


04:33p 


<DIR> 


message 


#2/06/00 


04:33p 


<DIR> 


service 


12/06/00 


04:33p 


<DIR> 


test 


12/06/00 


04:33p 


<DIR> 


types 


12/06/00 


04:33p 


<DIR> 


util 




11 File(s) 




333 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\se 
rvices\management\logger\client 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 4,325 ESLogClient . java 

12/15/99 04:00p 434 Makefile 

5 File(s) 4,759 bytes 
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test 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net \espeak\se 
rvices\raanagement\logger\client\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File(s) 



101 
81 
46 

846 
1, 074 



Entries 

Repository 

Root 

Template 
bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\se 
rvices\management\logger\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
£12/16/99 
112/16/99 
S12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
06:21p 
7 



<DIR> 
<DIR> 



File (s) 



48 Entries 
110 Entries. Log 

74 Repository 

4 6 Root 
8 46 Template 
1,124 bytes 



Ijl Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
Pttvices\management\ logger \manager 



i« 12/06/00 
ML2/06/00 
1112/06/00 
QL2/07/99 
312/07/99 
QL2/07/99 
-12/15/99 



04:33p 
04:33p 
04 : 33p 
04:26p 
04 :26p 
04:26p 
04 : OOp 
7 



<DIR> 
<DIR> 

<DIR> 



File (s) 



CVS 

9,765 ESLogServiceServlet . 

69 ESLogServiceManager, 
7,964 ESLogServiceManager, 

473 Makefile 
18,271 bytes 



java 

properties 
java 



Directory of E : \e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\management\logger\manager\CVS 

12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\se 
rvices\management\logger\message 



04:33p <DIR> 




04:33p <DIR> 




06:21p 


237 Entries 


06:21p 


82 Repository 


06:21p 


4 6 Root 


06:21p 


846 Template 


6 File(s) 


1,211 bytes 
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test 



12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


:33p 


<DIR> 




CVS 


12/07/99 


04 


:26p 




13, 666 


ESLogMessage 


12/07/99 


04 


:26p 




405 


Makefile 



5 File(s) 14,071 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\se 
rvices\management\logger\message\CVS 



12/06/00 


04:33p 


<DIR> 






12/06/00 


04:33p 


<DIR> 






12/16/99 


06:21p 




102 


Entries 


12/16/99 


06:21p 




82 


Repository- 


12/16/99 


06:21p 




46 


Root 


12/16/99 


06:21p 




846 


Template 



6 File(s) 1,076 bytes 

j 

JJ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
\f vices \management\ logger \ service 



1112/06/00 


04 


:33p <DIR> 






ifl.2/06/00 


04 


:33p <DIR> 






112/06/00 


04 


:33p <DIR> 




CVS 


,12/07/99 


04 


: 26p 


18, 657 


ESLogFileWriter . java 


« 12/07/99 


04 


:26p 


3, 693 


ESLoggerWaitQueue . j ava 


1*12/07/99 


04 


:26p 


16,773 


ESLogMessageParser . j ava 


1112/07/99 


04 


:26p 


2,281 


ESLogServicelntf . esidl 


112/07/99 


04 


:26p 


4,131 


ESLogServiceStub . j ava 


312/07/99 


04 


:26p 


1, 135 


ESLogServicelntfMessageRegistry 


O j ava 










£12/07/99 


04 


: 26p 


2,281 


ESLogServicelntf. java 


'12/07/99 


04 


:26p 


3,737 


ESLogServicelmpl . j ava 


12/07/99 


04 


:26p 


741 


Makefile 


12/07/99 


04 


:26p 


2,727 


ServicePackageWhiteBoxTest .java 


12/07/99 


04 


:26p 


4, 995 


TestDenialOf Service . j ava 


12/07/99 


04 


:26p 


4,380 


TestEscapeProcessing . j ava 


12/07/99 


04 


:26p 


12, 892 


TestFileWriting. java 


12/07/99 


04 


:26p 


6,023 


TestQueueProcessing . java 






17 File(s) 


84,446 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\se 
rvices \raanagement \ logger \service\CVS 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:21p 839 Entries 
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12/16/99 
12/16/99 
12/16/99 



06:21p 
06:21p 
06:21p 

6 File(s) 



test 

82 Repository 
46 Root 
84 6 Template 
1,813 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\management\logger\test 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04 :33p 
04 :33p 
04:26p 
04:26p 
04:26p 
6 



<DIR> 
<DIR> 
<DIR> 



File(s] 



CVS 

2,058 ESLoggerTest. java 
4,297 ESLoggerDefaultTest , 
403 Makefile 
6,758 bytes 



]ava 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\management\logger\test\CVS 



ill2/06/00 
\12/ 06/00 
U12/16/99 
FI12/16/99 
312/16/99 
.U2/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



163 Entries 
79 Repository 
4 6 Root 

84 6 Template 
1,134 bytes 



W= Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
!ltvices\management\logger\ types 



S3I12/06/00 


04 


: 33p 


<DIR> 






S&2/06/00 


04 


:33p 


<DIR> 






CIL2/06/00 


04 


: 33p 


<DIR> 




CVS 


12/07/99 


04 


:26p 




3,888 


ESLoggableDataltem. java 


12/07/99 


04 


:26p 




4, 928 


ESLoggableDataltemList . j ava 


12/07/99 


04 


:26p 




3,485 


ESLoggableBoolean . java 


12/07/99 


04 


:26p 




3,481 


ESLoggableString . j ava 


12/07/99 


04 


:26p 




3, 531 


ESLoggablelnteger . j ava 


12/07/99 


04 


:26p 




3, 529 


ESLoggableFloat . java 


12/07/99 


04 


:26p 




4, 459 


ESLoggableDate . j ava 


12/07/99 


04 


:26p 




547 


Makefile 






11 


File (s) 


27, 84* 


3 bytes 



Directory of E : \e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices \management\ logger \types\CVS 



12/06/00 
12/06/00 



04:33p 
04:33p 



<DIR> 
<DIR> 



Page 86 



12/16/99 
12/16/99 
12/16/99 
12/16/99 



06:21p 
06:21p 
06:21p 
06:21p 
6 



test 
461 
80 
46 
846 



Entries 

Repository 

Root 

Template 



File (s) 



1,433 bytes 



Directory of E: \e-speak-src_9 91217 \platform\ES\src\j ava\net\espeak\se 
rvices\management\logger\util 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 
5 



<DIR> 
<DIR> 
<DIR> 



File (s) 



CVS 

2,286 ESLoggableDateFormat . java 
381 Makefile 
2,667 bytes 



Di 
rvi 

KL2/ 
\12/ 

UJL2/ 
1112/ 
J12/ 
1112/ 



rectory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
ces\management\logger\util\CVS 



06/00 
06/00 
16/99 
16/99 
16/99 
16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



110 Entries 
7 9 Repository 
4 6 Root 

846 Template 
1,081 bytes 



w Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
fiJrvices\management\policymanager 



iXjl2/06/00 


04 


: 33p 


<DIR> 






OL2/06/00 


04 


: 33p 


<DIR> 






Q12/06/00 


04 


:33p 


<DIR> 




CVS 


12/06/00 


04 


: 33p 


<DIR> 




f ilingsystem 


12/15/99 


04 


: OOp 




1,397 


Makefile 


12/07/99 


04 


:26p 




2,330 


PersistenceFailureException. jav 


a 

12/07/99 


04 


:26p 




2,207 


PolicyLif ecycleListener . j ava 


12/07/99 


04 


:26p 




5, 198 


PolicyManagerFactorylntf . j ava 


12/07/99 


04 


:26p 




30,027 


PolicyManagerFactorylmpl . j ava 


12/07/99 


04 


:26p 




2, 145 


PolicyManagerFactoryException. j 


ava 

12/07/99 


04 


:26p 




3, 828 


PolicyLif ecycleEvent . j ava 


12/07/99 


04 


:26p 




4,792 


PolicyManagerlntf . java 


12/07/99 


04 


:26p 




2,819 


PolicyManagerLinkageEvent . j ava 


12/07/99 


04 


:26p 




2,708 


PolicyManagerLoopExcept ion . j ava 


12/07/99 


04 


:26p 




1,817 


PolicyManagerFactorylntf Message 


Registry. 


java 
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test 




12/07/99 


04 


:26p 


6,568 


PolicyManagerStub. java 


12/07/99 


04 


:26p 


2,392 


PolicyChangedEvent . j ava 


12/07/99 


04 


:26p 


3,000 


PolicyManagerLif ecycleEvent . j av 


a 

12/07/99 


04 


:26p 


2,400 


PolicyNotFoundExcept ion. java 


12/07/99 


04 


: 2 6p 


Z , by4 


rolicyNanagerNorijinKeQiijXcep uion 


. java 










12/07/99 


04 


:26p 


2,247 


PolicyManagerLif ecycleListener . 


j ava 










12/07/99 


04 


:26p 


2,225 


PolicyManagerLinkageListener . j a 


va 

12/07/99 


04 


:26p 


2,219 


PolicyChangedListener . java 


12/07/99 


04 


:26p 


2, 549 


PolicyManagerExistenceException 


.java 










12/07/99 


04 


:26p 


1,394 


PolicyManagerlntfMessageRegistr 


y . java 










12/07/99 


04 


:26p 


5,720 


PolicyManagerFactorylntf , esidl 


12/07/99 


04 


:26p 


24,384 


PolicyManager Impl . j ava 


:;12/07/99 


04 


: 26p 


4,7 92 


PolicyManagerlntf. esidl 


Jl2/07/99 


04 


:26p 


6, 112 


PolicyManager FactoryStub . j ava 


•42/07/99 


04 


:26p 


2,188 


PolicyManager FactoryShutdownLis 


Utener . java 








1112/07/99 


04 


:26p 


2,069 


PolicyManager FactoryShutdownEve 


ijht . j ava 










•U2/06/00 


04 


:33p <DIR> 




servlet 






32 File(s) 


132,221 bytes 



^ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
!rvices\management\policymanager\CVS 



112/06/00 
112/06/00 
112/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
06:21p 

7 File(s) 



<DIR> 
<DIR> 



1,805 Entries 

39 Entries. Log 
81 Repository 
46 Root 
84 6 Template 
2,817 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\se 
rvices\management\policymanager\f ilingsystem 



12/06/00 


04 


:33p 


12/06/00 


04 


:33p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


va 






12/06/00 


04 


: 33p 



<DIR> 
<DIR> 



<DIR> 



8 r 047 ChangeList . java 

1,931 CorruptedPolicyFileException. ja 

CVS 



Page 88 



test 



12/07/99 


04 


:26p 


13,747 


FileFormatter . j ava 


12/07/99 


04 


:26p 


9,032 


FileLoader . j ava 


12/07/99 


04 


:26p 


5, 168 


FileUtil . java 


12/07/99 


04 


:26p 


17,791 


FilingSystemPersistencyManager . 


j ava 










12/07/99 


04 


:26p 


33 


FilingSystemPersistencyManager . 


properties 








12/15/99 


04 


:00p 


590 


Makefile 


12/07/99 


04 


: 26p 


11,933 


PolicyManagerFile . j ava 



12 File(s) 68,272 bytes 



Directory of E: \e-speak-src__991217\platform\ES\src\ java\net\espeak\se 
rvices\management\policymanager\f ilingsystem\CVS 



12/06/00 


04:33p 


<DIR> 






12/06/00 


04:33p 


<DIR> 






12/16/99 


06:21p 




536 


Entries 


12/16/99 


06:21p 




94 


Repository 


"12/16/99 


06:21p 




46 


Root 


1.2/16/99 


06:21p 




846 


Template 



6 File(s) 1,522 bytes 



11) Directory of E: \e-speak-src__991217\platf orm\ES\src\java\net\espeak\se 
i|rvices\management\policymanager\servlet 



.-12/06/00 


04:33p 


<DIR> 




=12/06/00 


04:33p 


<DIR> 




42/06/00 


04:33p 


<DIR> 


CVS 


112/15/99 


04 : OOp 




424 Makefile 


"12/07/99 


04:26p 




16,601 PolicyManagerServlet 




5 File 


(s) 


17,025 bytes 



Cl Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\se 
rvices\management\policymanager\servlet\CVS 



12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:21p 

12/16/99 06:21p 

12/16/99 06:21p 

12/16/99 06:21p 

6 File(s) 



<DIR> 
<DIR> 

110 Entries 
8 9 Repository 
4 6 Root 

84 6 Template 
1,091 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\management\processmanager 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
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test 



12/06/00 


04 


:33p 


<DIR> 


CVS 


12/07/99 


04 


: 26p 




349 Makefile 


12/06/00 


04 


:33p 


<DIR> 


service 


12/06/00 


04 


: 33p 


<DIR> 


shell 


12/06/00 


04 


: 33p 


<DIR> 


statemonitor 


12/06/00 


04 


:33p 


<DIR> 


test 


12/06/00 


04 


: 33p 


<DIR> 


util 


12/06/00 


04 


: 33p 


<DIR> 


web 






10 


File (s) 


349 bytes 



Directory of E: \e-speak-src_9 91217\platform\ES\src\java\net\espeak\se 
rvice s \raanagement \proces smanager \CVS 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:21p 48 Entries 

12/16/99 06:21p 95 Entries. Log 

12/16/99 06:21p 82 Repository 

£12/16/99 06:21p 46 Root 

412/16/99 06:21p 846 Template 

%l 7 File(s) 1,117 bytes 

ft| Directory of E:\e-speak-src_991217\platforra\ES\src\java\net\espeak\se 
3rvices\raanagement\proces smanager \service 

-12/06/00 04:33p <DIR> 

■» 12/06/00 04:33p <DIR> 

kl2/06/00 04:33p <DIR> CVS 

rfi.2/07/99 04:26p 652 Makefile 

51.2/07/99 04:26p 2,226 ProcessManagerException . java 

81.2/07/99 04:26p 4, 494 ProcessManager . j ava 

C-12/07/99 04:26p 5,155 ProcessManagerServicelntf . esidl 

£1.2/07/99 04:26p 8,380 ProcessManagerServiceStub . j ava 

12/07/99 04:26p 1,923 ProcessManagerException . esidl 

12/07/99 04:26p 1,393 ProcessManagerServicelntfMessag 
eRegistry . java 

12/07/99 04:26p 5,155 ProcessManagerServicelntf . j ava 

12/07/99 04:26p 10,069 ProcessManagerService . java 

12 File(s) 39,447 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\j ava\net\espeak\se 
rvices\management\proces smanager \service\CVS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:21p 582 Entries 

12/16/99 06:21p 90 Repository 

12/16/99 06:21p 46 Root 
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12/16/99 



06:21p 

6 File(s) 



test 

84 6 Template 
1,564 bytes 



Directory of E : \e-speak-src_9 91217 \platform\ES\src\j ava\net\espeak\se 
rvices\management\processraanager\shell 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
7 



<DIR> 
<DIR> 
<DIR> 



File (s) 



CVS 

427 Makefile 
11,963 PMShellService. java 
24,7 00 PMShellConsole. java 

4,103 PMShell.java 

41,193 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\se 
rvices\management\processmanager\shell\CVS 



•■••12/06/00 
1.2/06/00 
42/16/99 
! ,12/16/99 
i|l2/16/99 
512/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File(s) 



209 Entries 
88 Repository 
4 6 Root 

84 6 Template 
1,189 bytes 



;s Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
Services \management\processmanager\statemoni tor 



1512/06/00 
312/06/00 
512/07/99 
&2/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04: 

04: 

04: 

04: 

04: 

04: 

04: 

04: 

04: 

04 

04 

04 

04 

04 

04 



33p 
33p 
26p 
33p 
26p 
26p 
26p 
26p 
26p 
26p 
26p 
26p 
26p 
26p 
26p 
15 



<DIR> 
<DIR> 

<DIR> 



File (s) 



CoreConnectionMonitor . j ava 
CVS 

ESJoblntf . java 
ESJob. java 
In JVM Job. java 
Makefile 

MonitorlniFile . j ava 
Process Job . j ava 
StateMonitorlntf . java 
StateMonitorException . j ava 
StateMonitorConf ig . j ava 
StateMonitor . j ava 
Tas kErrStreamMonit or . j ava 
42, 068 bytes 



4, 


182 


3, 


129 


1, 


868 


3, 


731 




641 


4, 


007 


5, 


260 


3, 


947 


1, 


794 


4, 


679 


3, 


468 


5, 


362 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\se 
rvices\management\processmanager\statemonitor\CVS 



Page 91 



test 



12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:21p 

12/16/99 06:21p 

12/16/99 06:21p 

12/16/99 06:21p 

6 File(s) 



<DIR> 
<DIR> 

664 Entries 
95 Repository 
46 Root 

846 Template 
1 , 651 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\se 
rvices\management\processmanager\test 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 378 Makefile 

12/07/99 04:26p 176 TEST . ESH 

12/07/99 04:26p 2,416 TestTask. java 

Q 6 File (s) 2, 97 0 bytes 

%? 

%\ Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
Ulrvices\management\processmanager\test\CVS 

0112/06/00 04:33p <DIR> 
11112/06/00 04:33p <DIR> 

W12/16/99 06:21p 143 Entries 

« 12/16/99 06:21p 87 Repository 

KL2/16/99 06:21p 46 Root 

FIJ12/16/99 06:21p 846 Template 

51 6 File(s) 1,122 bytes 

fil Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
0rvices\management\processmanager\util 



12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 






12/07/99 


04 


:26p 




3, 136 


ClientHelper . java 


12/07/99 


04 


: 2 6p 




3, 815 


CommandLine . j ava 


12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/07/99 


04 


:26p 




3,272 


InJVMRunner .java 


12/07/99 


04 


:26p 




2, 979 


IOPipe. java 


12/07/99 


04 


:26p 




493 


Makefile 


12/07/99 


04 


:26p 




3,715 


SimpleLoader . j ava 






9 


File (s) 


17,410 bytes 



Directory of E : \e- speak- src__9 9121 7 \platform\ES\src\java\net\espeak\se 
rvices\management\processmanager\util\CVS 
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12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



test 



310 Entries 
87 Repository 
4 6 Root 

846 Template 
1,289 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net \espeak\se 
rvices\management\processmanager\web 



12/06/00 
12/06/00 
12/06/00 
12/15/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:00p 
04:26p 
04:26p 

6 File(s) 



<DIR> 
<DIR> 
<DIR> 



CVS 

447 Makefile 
12,009 PMShellServlet. java 
12 9 servlet . properties 
12,585 bytes 



lii Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
%rvices\management\processmanager\web\CVS 



SlJ.2/06/00 
312/06/00 
112/16/99 
1*12/16/99 
.12/16/99 
1-12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



159 Entries 
8 6 Repository 
4 6 Root 

84 6 Template 
1,137 bytes 



II Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
Itvices\management\servicemanager 



12/06/00 


04 


: 33p 


12/06/00 


04 


:33p 


12/06/00 


04 


: 33p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


ava 






12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 



<DIR> 
<DIR> 
<DIR> 



CVS 

848 Makefile 
9, 820 ServiceManager. java 
3, 322 ServicelnstanceManager . java 
9, 858 ServiceEventHandler . java 
2, 093 ServicelnstanceManagerFailure . j 

2,142 ServiceCont roller Failure . j ava 

2 , 082 ServiceEventHancilerFailure . java 

7, 351 ServiceController . java 

2,289 ServiceManager Intf . esidl 

5, 091 ServiceManagerStub. java 

1,273 ServiceManagerlntfMessageRegist 
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test 



ry . java 
12/07/99 
12/07/99 
12/06/00 



04:26p 
04:26p 
04 : 33p 
17 



File (s) 



2,318 ServiceManagerlntf . j ava 
2,714 ServiceManagerlmpl. java 
<DIR> ui 

51,201 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\s< 
rvices\management\servicemanager\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
06:21p 



<DIR> 
<DIR> 



7 File(s) 



809 Entries 
12 Entries. Log 
82 Repository 
4 6 Root 

846 Template 
1,795 bytes 



3 Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\s 
It vices \management\servicemanager\ui 



46.2/06/00 04:33p 
%2/06/00 04:33p 
•%2/07/99 04:26p 
"ML2/06/00 04:33p 
04:00p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
13 



<DIR> 
<DIR> 



<DIR> 



^12/15/99 
; 12/07/99 
::l2/07/99 
"S:i2/07/99 
,??12/07/99 
|?12/07/99 
&2/07/99 
^12/07/99 
12/07/99 



File (s) 



1,888 ChangeStateFailed. java 
CVS 

842 Makefile 
2,036 ModelException. j ava 
6,867 ServiceManagerUI . java 
3, 470 ServiceManagerTableModel .java 
15, 0 99 ServiceManagerServlet . java 
21,904 ServiceManagerModel . java 
193 servlet .properties 
8, 894 UiServiceManagerAdapter . j ava 
6,577 UiServiceManager . java 
67,770 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\s 
rvices\management\servicemanager\ui\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 



<DIR> 
<DIR> 



6 File(s) 



589 Entries 
85 Repository 
46 Root 

84 6 Template 
1,566 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\s 
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rvi ce s \management \web 



test 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/06/00 04:33p <DIR> servlets 

4 File(s) 0 bytes 

Directory of E : \e-speak-src_9 91217 \platforra\ES\src\java\net\espeak\se 
rvices\management\web\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:21p 3 Entries 

12/16/99 06:21p 18 Entries. Log 

12/16/99 06:21p 71 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

Q 7 File(s) 984 bytes 

%f Directory of E: \e-speak-src_991217\platf orm\ES\src\j ava\net\espeak\se 
U±vices\management\web\ servlets 

312/06/00 04:33p <DIR> 
1112/06/00 04:33p <DIR> 

-12/07/99 04:26p 7,457 CoreServlet . java 

ia2/06/00 04:33p <DIR> CVS 

=42/15/99 04:00p 461 Makefile 

1112/07/99 04:26p 10, 758 ManagementServlet . j ava 

5l 6 File(s) 18, 676 bytes 

□ Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\se 
Crvices\management\web\servlets\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:21p 160 Entries 

12/16/99 06:21p 80 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

6 File(s) 1,132 bytes 

Directory of E : \e-speak-src_9 91217 \plat f orm\ES\src\j ava\net\espeak\se 
rvices\tunnel 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:26p 6, 943 AbstractSocket . java 
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test 




12/07/99 


04:26p 


1, 894 


AcceptedSocket . j ava 


12/07/99 


04:26p 


2,219 


ByteArray . java 


12/07/99 


04:26p 


1,781 


ClientSocketFactorylF. java 


12/07/99 


04:26p 


2,525 


ClientSocketFactory . java 


12/07/99 


04:26p 


2, 428 


ClientSocket . j ava 


12/07/99 


04:26p 


700 


compile . bat 


12/07/99 


04 :26p 


2,227 


ConnectTunnelClientlF. java 


12/06/00 


04:33p <DIR> 




CVS 


12/07/99 


04:26p 


6,227 


Dialog . j ava 


12/07/99 


04:26p 


3,218 


ESClientSocketFactoryStub . j ava 


12/07/99 


04:26p 


2, 984 


ESClientSocketFactorySkel . java 


12/07/99 


04:26p 


1,777 


ESClientSocketFactorylF. j ava 


12/07/99 


04 :26p 


2,203 


ESConnectTunnelClientlF. j ava 


12/07/99 


04:26p 


4,777 


ESConnectionFinder . j ava 


12/07/99 


04:26p 


245 


esdriver 


12/07/99 


04:26p 


7, 531 


ESDriver . j ava 


12/07/99 


04:26p 


3, 970 


ES Socket Stub . j ava 


12/07/99 


04:26p 


5, 860 


ESSocketSkel .java 


-il2/07/99 


04:26p 


1,861 


ESSocketlF. java 


"SL2/07/99 


04:26p 


3,210 


ESTunnelServiceStub . j ava 


! yp.2/07/99 


04:26p 


3,413 


ESTunnelServiceSkel . j ava 


ifl.2/07/99 


04:26p 


2, 802 


ESTunnelServicelF. j ava 


;1CL2/07/99 


04:26p 


1, 114 


Makefile 


30.2/07/99 


04:26p 


0 


Makefile . dep 


;1J12/07/99 


04 : 26p 


518 


makefile . release 


Cl2/07/99 


04 : 26p 


1, 724 


Model IF . j ava 


n 12/07/99 


04:26p 


2,789 


PassiveSocket . j ava 


W2/07/99 


04:26p 


2, 195 


SimpleConnectionFinder . j ava 


11112/07/99 


04:26p 


1,674 


SocketRegistrylF. j ava 


Q12/07/99 


04:26p 


1, 686 


Socket InternlF. java 


15112/07/99 


04:26p 


1,788 


SocketlF. java 


GE2/07/99 


04:26p 


252 


tscmd 


2/07/99 


04 : 26p 


4,534 


TSCmd. java 


12/07/99 


04:26p 


2, 782 


TunnelServicelF. java 


12/07/99 


04:26p 


6,878 


TunnelService . j ava 


12/07/99 


04:26p 


7,590 


TunnelAttributes . j ava 




39 File(s) 


106,319 bytes 


Directory of E:\e-speak-src_ 


991217\platf orm\ES\src\ java\net\espeak\s 


rvices\ tunnel \CVS 






12/06/00 


04:33p <DIR> 






12/06/00 


04:33p <DIR> 






12/16/99 


06:21p 


2, 001 


Entries 


12/16/99 


06:21p 


63 


Repository 


12/16/99 


06:21p 


46 


Root 


12/16/99 


06:21p 


846 


Template 




6 File(s) 


2, 956 bytes 
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test 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net \espeak\ut 
il 



12/06/00 


04 


:33p 


<DIR> 






m 


12/06/00 


04 


:33p 


<DIR> 








12/07/99 


04 


:26p 




6, 


191 


Assert . java 


12/07/99 


04 


:26p 




2, 


023 


Codecoverage . j ava 


12/07/99 


04 


:26p 




2, 


289 


CoverageThread. java 


12/06/00 


04 


:33p 


<DIR> 






CVS 


12/07/99 


04 


:26p 




3, 


729 


ErrorMsg . j ava 


12/07/99 


04 


:26p 




15, 


301 


ESAbstractWriter . java 


12/07/99 


04 


:26p 




9, 


088 


ESArray . java 


12/07/99 


04 


:26p 




2, 


605 


ESContainer . j ava 


12/07/99 


04 


:26p 




26, 


220 


ESDebug. java 


12/07/99 


04 


:26p 




5, 


855 


ESFileWriter . java 


12/06/00 


04 


:33p 


<DIR> 






esidl 


12/07/99 


04 


:26p 




6, 


271 


ESList . java 


^12/07/99 


04 


:26p 




3, 


817 


ESLogStream. j ava 


;}<L2/07/99 


04 


:26p 




2, 


997 


ESMapNode . j ava 


£12/07/99 


04 


:26p 




16, 


204 


ESMap. java 


UJL2/07/99 


04 


:26p 




2, 


747 


ESPrintWriter . j ava 


S|L2/07/99 


04 


:26p 




4, 


619 


ESSet . java 


142/07/99 


04 


:26p 




6, 


346 


ESString. java 


112/07/99 


04 


:26p 




10, 


178 


ESStrings . java 


1*12/07/99 


04 


:26p 




17, 


634 


ESText . java 


,12/07/99 


04 


:26p 




14, 


600 


ESTracer . java 


WL2/07/99 


04 


:26p 




2, 


099 


ExternalLogger . j ava 


1112/07/99 


04 


:26p 




6, 


221 


FileServerServlet . j ava 


12112/07/99 


04 


:26p 




7, 


029 


GenericListenerList . java 


1^.2/07/99 


04 


: 26p 




19, 


-890 


IniFile . j ava 


C12/06/00 


04 


: 33p 


<DIR> 






io 


112/15/99 


04 


: OOp 




1, 


,400 


Makefile 


12/06/00 


04 


:33p 


<DIR> 






misc 


12/07/99 


04 


: 2 6p 




4, 


.161 


NullPrintStream. java 


12/07/99 


04 


: 26p 




4, 


,350 


Poll . java 


12/07/99 


04 


:26p 




50, 


,112 


SysLoader . j ava 


12/07/99 


04 


:26p 




6, 


,639 


Taskln JVM. java 


12/07/99 


04 


:26p 




3, 


, 646 


TaskLoader . java 


12/07/99 


04 


:26p 




8, 


,240 


TaskNew JVM. java 


12/07/99 


04 


:26p 




6, 


,598 


TaskRemote . java 


12/07/99 


04 


:26p 




7, 


,785 


TaskReader . java 


12/07/99 


04 


:26p 




4, 


,939 


TaskServer . java 


12/07/99 


04 


:26p 




3, 


, 170 


TaskWatcher . java 


12/07/99 


04 


: 26p 




32, 


, 665 


Task. java 


12/07/99 


04 


: 26p 




3, 


,430 


TestHelper . java 


12/07/99 


04 


:26p 




6 


, 416 


Trace. java 


12/06/00 


04 


: 33p 


<DIR> 






ts 
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12/06/00 04:33p 
12/07/99 04:26p 

46 File(s) 



test 

<DIR> tsutil 

6,296 UniquelD. java 
343,800 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\ut 
il\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
06:21p 
7 



<DIR> 
<DIR> 



File (s) 



1,957 Entries 

69 Entries. Log 
52 Repository 
4 6 Root 
846 Template 
2, 970 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\ut 



il\esidl 












|l2/06/00 


04 


: 33p 


<DIR> 






W2/06/00 


04 


: 33p 


<DIR> 






UR2/07/99 


04 


:26p 




11,106 


CodeGen. java 


1112/06/00 


04 


:33p 


<DIR> 




CVS 


5112/07/99 


04 


:26p 




32,286 


IDLCompiler . java 


11112/07/99 


04 


:26p 




13,857 


IDLTypeRepository . java 


-12/07/99 


04 


:26p 




3,997 


IraportedTypeRepository . j ava 


» 12/07/99 


04 


:26p 




2, 391 


InvalidlDLTypeException. java 


1**12/07/99 


04 


:26p 




593 


Makefile 


FIJ12/07/99 


04 


:26p 




20, 659 


Marshaller . java 


$12/07/99 


04 


:26p 




3,320 


MyPrintWriter . j ava 


3112/07/99 


04 


:26p 




7,153 


Primiti veTypeMap . j ava 


©12/07/99 


04 


:26p 




18, 662 


StubCompiler . java 


©12/07/99 


04 


:26p 




18, 593 


TypeValidator . j ava 


12/07/99 


04 


:26p 




14, 618 


Utils . j ava 



15 File(s) 



147,235 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\ut 
il\esidl\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04 : 33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (si 



659 Entries 
58 Repository 
46 Root 

84 6 Template 
1, 609 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\ut 
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test 



il\io 






12/06/00 


04 


:33p 


12/06/00 


04 


: 33p 


12/06/00 


04 


: 33p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:2 6p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 



<DIR> 
<DIR> 
<DIR> 



10 File(s; 



CVS 

5,283 FileOutputStream. java 

4,154 LogContext . java 

8,302 LogEnv.java 

7,550 Logger. java 

4,571 LogOutput St ream. java 

455 Makefile 
3,029 NullOutput St ream. java 
33,344 bytes 



Directory of E : \e-speak-src_991217\platform\ES\src\java\net\espeak\ut 
il\io\CVS 



12/06/00 

rrl2/06/oo 

&L2/16/99 
H2/16/99 

UH2/16/99 
11112/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



369 Entries 
55 Repository 
46 Root 

846 Template 
1,316 bytes 



k k Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\ut 



il\misc 






11112/06/00 


04 


:33p 


£$12/06/00 


04 


: 33p 


iJtL2/07/99 


04 


: 26p 


$5.2/07/99 


04 


:26p 


iS|l2/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


12/06/00 


04 


: 33p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 



<DIR> 
<DIR> 



<DIR> 



10 File(s) 



2,422 Array. java 
12,4 60 ByteArray . java 

4,536 ByteBuf f er . j ava 
10,566 Cons. java 
CVS 

429 Makefile 
5,387 Queue. java 
2,042 Testable. java 
37,842 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\ut 
il\misc\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 



<DIR> 
<DIR> 



341 Entries 
57 Repository 
4 6 Root 
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12/16/99 06:21p 

6 File(s] 



test 

84 6 Template 
1,290 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\ut 
il\ts 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
13.2/07/99 
.1512/07/99 
HJ12/07/99 
UIL2/07/99 
1E2/07/99 
312/07/99 
llH 2/07/99 
1^12/07/99 
« 12/07/99 
N12/07/99 
11112/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 

23 File(s) 



<DIR> 
<DIR> 
<DIR> 



CVS 

731 Makefile 

3,820 PrettyPrintManager . java 
49,630 TSAtomic. java 

5,305 TSBoolean. java 

2,8 67 TSDatePP. java 

2,764 TSDefaultFactory . java 

3,105 TSFactory. java 
10,751 TSLexical. java 
18,143 TSList.java 

2,829 TSMapEnumerat ion. java 
28,181 TSMap.java 

3,044 TSObservable. java 
22,612 TSParser. java 

2,237 TSParseException. java 

2,488 TSPrettyPrinter. java 

6,701 TSTest.java 
30,139 TSUtils.java 

8,17 9 TSValue.java 

3,771 TSVisitor. java 

2,520 TypeErrorExcept ion. java 
209, 817 bytes 



Q Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\ut 
CfcLl\ts\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



1,048 Entries 
55 Repository 
4 6 Root 
846 Template 
1, 995 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\ut 
il\tsutil 



12/06/00 04:33p 
12/06/00 04:33p 
12/06/00 04:33p 



<DIR> 
<DIR> 
<DIR> 



CVS 
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test 



12/07/99 


04 


:26p 


4, 605 


List . java 


12/07/99 


04 


:26p 


498 


Makefile 


12/07/99 


04 


:26p 


4,889 


Map . j ava 


12/07/99 


04 


:26p 


11,159 


Syn. java 


12/07/99 


04 


:26p 


2,545 


TSBinary . java 


12/07/99 


04 


: 26p 


2,335 


TSBoolean. java 


12/07/99 


04 


:26p 


2,342 


TSInteger . java 


12/07/99 


04 


:26p 


2, 310 


TSNumber . java 


12/07/99 


04 


:26p 


2,225 


TSString. java 


12/07/99 


04 


:26p 


2,165 


TSTag. java 


12/07/99 


04 


:26p 


2,426 


TSToken. java 



14 File(s) 37,499 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\ut 
il\tsutil\CVS 



12/06/00 
12/06/00 
©12/16/99 
£12/16/99 
SI12/16/99 
UJ12/16/99 



04 : 33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



532 Entries 
59 Repository 
4 6 Root 
8 46 Template 
1,483 bytes 



it) Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\we 
Wbaccess 



1^12/06/00 
^12/06/00 
012/06/00 
3112/07/99 
'5112/07/99 
©12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/15/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04 :26p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04 :26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:33p 
04:26p 
04 : OOp 
04 :26p 
04 :26p 



<DIR> 
<DIR> 
<DIR> 



<DIR> 



<DIR> 



conf 

3,264 Converterlntf . java 
2,913 Converterlnfo. java 
CVS 

3,7 65 DispatchTable . java 
15,409 ESConverter . java 
10,988 ESFormMapper . java 
11,250 ESMapper . java 
2,067 ESMessageXml . java 
5,440 ESProcessor. java 
4,423 FormGenericMapper . java 
4,589 FormLoginMapper. java 
3,703 GenericMapper. java 
6,801 GenericConverter . java 

htdocs 
4,429 Mailbox. java 
1,385 Makefile 

634 makefile. release 
3,165 Mapperlnfo. java 
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test 




12/07/99 


04 


:26p 




2, 573 


Mapperlntf . j ava 


12/07/99 


04 


: 26p 




2,040 


Processor Intf . j ava 


12/07/99 


04 


:26p 




2,716 


Processorlnf o . j ava 


12/07/99 


04 


: 26p 




3, 667 


Queue . java 


12/07/99 


04 


: 26p 




2,257 


RequestBadReques t . j ava 


12/07/99 


04 


:26p 




2,288 


RequestNot Found . j ava 


12/07/99 


04 


:26p 




2,265 


RequestNoContent . j ava 


12/07/99 


04 


:26p 




2,267 


RequestMultipleChoice . j ava 


12/07/99 


04 


: 26p 




2,241 


RequestForbidden . j ava 


12/07/99 


04 


:26p 




4, 866 


ServiceDaemon . j ava 


12/07/99 


04 


:26p 




4,779 


ServiceTranslator . j ava 


12/07/99 


04 


:26p 




3,155 


ServiceTable . j ava 


12/07/99 


04 


:26p 




7, 992 


ServiceHandler . j ava 


12/07/99 


04 


:26p 




16,885 


ServiceDispatcher . j ava 


12/07/99 


04 


:26p 




5, 929 


SessionTable . j ava 


12/07/99 


04 


: 26p 




2, 971 


Session. java 


12/07/99 


04 


:26p 




3,732 


TranslationTable . j ava 


12/07/99 


04 


:26p 




5,255 


URLBinder . j ava 


,•5-2/07/99 


04 


:26p 




3,455 


URLCache . j ava 


112/07/99 


04 


:26p 




7,845 


URLConverter . j ava 


:yL2/07/99 


04 


:26p 




6,889 


Util .java 


,,12/07/99 


04 


: 26p 




2, 663 


WAExcept ionlnf o . j ava 


512/07/99 


04 


:26p 




2,472 


WANameList . j ava 


112/07/99 


04 


:26p 




6, 942 


WebAccess . j ava 


1112/07/99 


04 


:26p 




9,263 


XMLApp3 .java 






46 


File (s) 


201, 632 bytes 


hi Directory of E : 1 


\e-speak-src_' 


991217\platform\ES\src\ j ava\net\espe. 


f|baccess\conf 










|fL2/06/00 


04 


: 33p 


<DIR> 






SL2/06/00 


04 


:33p 


<DIR> 






I2IL2/06/00 


04 


: 33p 


<DIR> 




CVS 


12/07/99 


04 


:26p 




27,318 


httpd. conf 


12/06/00 


04 


:33p 


<DIR> 




j serv 






5 


File(s) 


27,31! 


3 bytes 



Directory of E : \e-speak-src_991217 \platf orm\ES\src\ java\net\espeak\we 
baccess\conf \CVS 



12/06/00 


04:33p <DIR> 




12/06/00 


04:33p <DIR> 




12/16/99 


06:21p 


50 Entries 


12/16/99 


06:21p 


15 Entries. Log 


12/16/99 


06:21p 


62 Repository 


12/16/99 


06:21p 


46 Root 


12/16/99 


06:21p 


84 6 Template 




7 File(s) 


1,019 bytes 
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test 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\we 
baccess\conf \ j serv 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 
04:26p 



<DIR> 
<DIR> 
<DIR> 



6 File(s) 



CVS 

6,559 jserv.conf 
12,790 jserv. properties 
6,496 zone. properties 
25,845 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net \espeak\we 
baccess\conf \ j serv\CVS 



12/06/00 
12/06/00 
12/16/99 
•3L2/16/99 
ilI12/16/99 
^2/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



155 Entries 
68 Repository 
46 Root 

846 Template 
1,115 bytes 



||! Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\we 
:1fc>access\CVS 



* 12/06/00 
M12/06/00 
iUl2/16/99 
©12/16/99 
3112/16/99 
312/16/99 
012/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
06:21p 

7 File(s; 



<DIR> 
<DIR> 



2,218 Entries 

30 Entries. Log 
57 Repository 
4 6 Root 
846 Template 
3,197 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\we 
baccess\htdocs 



12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/07/99 


04 


:26p 




12/07/99 


04 


:26p 




12/07/99 


04 


:26p 




12/07/99 


04 


:26p 




12/06/00 


04 


: 33p 


<DIR> 


12/07/99 


04 


:26p 




12/07/99 


04 


:26p 




12/07/99 


04 


:26p 





699 ask-lu-vocab.html 

7 03 ask-reg-vocab . html 

665 book-buying . html 

509 button-back-to-register . gif 
CVS 

11,638 ESPEAK.jpg 

886 green-ball . gif 

1,454 index.html 

Page 103 



test 



12/07/99 


04 


:26p 


1, 107 


login-reply . html 


12/07/99 


04 


:26p 


1,102 


logo . gif 


12/07/99 


04 


:2 6p 


1,265 


lookup-f orm. html 


12/07/99 


04 


:26p 


691,318 


mayl0ic.bmp 


12/07/99 


04 


:26p 


41,279 


maylOic . jpg 


12/07/99 


04 


:26p 


1,522 


register-form. html 


12/06/00 


04 


:33p 


<DIR> 


servlets 


12/07/99 


04 


:26p 


148, 992 


web-espeak slides. ppt 


12/07/99 


04 


:26p 


5,346 


welcomenew.gif 



19 File(s) 908,485 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\we 
baccess\htdocs\CVS 



12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:22p 

12/16/99 06:22p 

^12/16/99 06:21p 

B12/16/99 06:21p 

Cjl2/16/99 06:21p 

i 7 File(s) 



<DIR> 
<DIR> 



785 Entries 
18 Entries. Log 
64 Repository 
4 6 Root 

84 6 Template 
1,759 bytes 



ijl Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\we 
ribaccess\htdocs\ servlets 



u 12/06/00 
^12/06/00 
11112/07/99 
□12/06/00 
0112/07/99 
□12/07/99 
2112/07/99 
12/15/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04:00p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
14 



<DIR> 
<DIR> 

<DIR> 



File (s) 



20,614 BookBroker . java 
CVS 

7,045 Forms. java 

6,645 HTML2XML. java 

4,089 IsItWorking. java 

575 Makefile 

40 proxy. cfg 

10,518 ProxyBarnes . java 

12,489 Proxy FatBrain. java 

3,578 Proxylnf o . java 

5,4 67 ShowRegistrationForm. j ava 

2,224 XMLDocTags. java 

73,284 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\we 
baccess\htdocs\servlets\CVS 



12/06/00 04:33p 
12/06/00 04:33p 
12/16/99 06:22p 



<DIR> 
<DIR> 



569 Entries 
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12/16/99 
12/16/99 
12/16/99 



06:22p 
06:22p 
06:22p 
6 



File (s) 



test 

73 Repository 
4 6 Root 
8 46 Template 
1,534 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\perl 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
4 File(s) 



CVS 
plesi 
0 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\perl\CVS 



12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:22p 

□12/16/99 06:22p 

£12/16/99 06:22p 

'412/16/99 06:22p 

UI12/16/99 06:22p 



<DIR> 
<DIR> 



7 File(s) 



3 Entries 
15 Entries. Log 
36 Repository 
4 6 Root 
8 46 Template 
946 bytes 



ill Directory of E:\e-speak-src_991217\platform\ES\src\perl\plesi 



12/06/00 
1=^12/06/00 
il!l2/07/99 
012/07/99 
3112/07/99 
CI12/06/00 
5112/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04 : 33p 
04:26p 
04:26p 
04:26p 
04: 33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 

17 File(s) 



<DIR> 
<DIR> 



<DIR> 



9,832 ABI.pm 
10,309 abi2c.pl 
2,220 abi2txt.pl 
CVS 

18,584 ESLib.pm 
13,760 ESReader.pm 

8,467 ESUtil.pm 

7,139 ESWriter.pm 

7,051 logexpand.pl 
15,799 README . txt 

2,636 rtc.pl 

4,849 rts.pl 

2,019 sigbytes.pl 

2,701 tc.pl 

3,179 ts.pl 
108,545 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\perl\plesi\CVS 
12/06/00 04:33p <DIR> 
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12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
06:22p 
06:22p 
06: 22p 
06:22p 
6 



<DIR> 



File (s) 



test 

639 Entries 
42 Repository 
46 Root 

84 6 Template 
1,573 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\python 



12/06/00 
12/06/00 
12/06/00 
12/06/00 



04:33p 
04:33p 
04:33p 
04:33p 



<DIR> 
<DIR> 
<DIR> 
<DIR> 



4 File(s) 



CVS 
pyesi 
0 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\python\CVS 



12/06/00 
"112/06/00 
Jl2/16/99 
Cjl2/16/99 
UJ12/16/99 
!t]12/16/99 
15*12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
06:22p 

7 File (si 



<DIR> 
<DIR> 



3 Entries 
15 Entries. Log 
38 Repository 
4 6 Root 
846 Template 
948 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\python\pyesi 



11112/06/00 


04: 


: 33p 


<DIR> 






£112/06/00 


04: 


:33p 


<DIR> 






$12/06/00 


04: 


;33p 


<DIR> 




abi 


012/06/00 


04: 


: 33p 


<DIR> 




CVS 


1112/06/00 


04: 


: 33p 


<DIR> 




io 


12/06/00 


04: 


: 33p 


<DIR> 




net 


12/07/99 


04: 


:26p 




25,590 


README . txt 


12/06/00 


04; 


: 33p 


<DIR> 




util 


12/07/99 


04: 


:26p 




0 


init .py 



9 File(s) 



25,590 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\python\pyesi\abi 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
12/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:33p 
04:26p 



<DIR> 
<DIR> 



<DIR> 



17,585 abi.py 

2,480 abi2txt.py 
48,218 abiobj.py 
CVS 

18,088 eslib.py 
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test 




12/07/99 


04 


:26p 


6,762 


esobj . py 


12/07/99 


04 


:26p 


2,476 


esutil . py 


12/07/99 


04 


:26p 


9, 925 


es_input_stream. py 


12/07/99 


04 


:26p 


11, 082 


es output_stream.py 


12/07/99 


04 


:26p 


10,554 


genabi .py 


12/07/99 


04 


:2 6p 


7,026 


genobj .py 


12/06/00 


04 


:33p <DIR> 




msg 


12/07/99 


04 


:26p 


5,049 


rtc.py 


12/07/99 


04 


:26p 


10, 667 


rts .py 


12/07/99 


04 


:26p 


2,168 


sigbytes.py 


12/07/99 


04 


:26p 


5,455 


tc.py 


12/07/99 


04 


:26p 


7,777 


ts .py 


12/07/99 


04 


:26p 


0 


init . py 






20 File(s) 


165,312 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\python\pyesi\abi\C 
VS 



rnL2/06/00 
/?a2/06/00 
Cfl.2/16/99 
fifl.2/16/99 
1112/16/99 
312/16/99 
1112/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06: 22p 
06:22p 

7 File(s) 



<DIR> 
<DIR> 



744 Entries 
13 Entries. Log 
48 Repository 
4 6 Root 

846 Template 
1,697 bytes 



j*= Directory of E:\e-speak-src_991217\platform\ES\src\python\pyesi\abi\m 

•Ijsg 



3112/06/00 


04 


: 33p 


<DIR> 








312/06/00 


04 


:33p 


<DIR> 








312/06/00 


04 


:33p 


<DIR> 




CVS 




12/07/99 


04 


:26p 




8 


msgOOOl. 


ser 


12/07/99 


04 


:26p 




117 


msg0002. 


ser 


12/07/99 


04 


:26p 




154 


msg0003. 


ser 


12/07/99 


04 


:26p 




53 


msg0004. 


ser 


12/07/99 


04 


:26p 




159 


msg0005. 


ser 


12/07/99 


04 


:26p 




53 


msg0006. 


ser 


12/07/99 


04 


:26p 




194 


msg0007 . 


ser 


12/07/99 


04 


:26p 




53 


msg0008 . 


ser 


12/07/99 


04 


: 26p 




151 


msg0009. 


ser 


12/07/99 


04 


:26p 




53 


msgOOlO. 


ser 


12/07/99 


04 


:26p 




353 


msgOOll. 


ser 


12/07/99 


04 


:26p 




53 


msg0012 . 


ser 


12/07/99 


04 


:26p 




275 


msg0013 . 


ser 


12/07/99 


04 


:26p 




53 


msg0014 . 


ser 


12/07/99 


04 


:26p 




8 


msg0015 . 


ser 
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12/07/99 


04: 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


012/07/99 


04 


:26p 


$12/07/99 


04 


:26p 


^12/07/99 


04 


:26p 


yJl2/07/99 


04 


:2 6p 


HI12/07/99 


04 


:26p 


W ?s =12/07/99 


04 


:26p 


rtJl2/07/99 


04 


:26p 


^12/07/99 


04 


:26p 


!i 12/07/99 


04 


:26p 


if 12/07/99 


04 


:26p 


$12/07/99 


04 


:26p 


§12/07/99 


04 


: 26p 


$12/07/99 


04 


: 26p 


§12/07/99 


04 


:26p 


$12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 



55 File(s) 



test 

117 msgOOie.ser 
154 msg0017.ser 
53 msg0018.ser 
159 msg0019.ser 

53 msg0020.ser 
136 msg0021.ser 

54 rasg0022.ser 
92 msg0023.ser 
54 msg0024.ser 

157 msg0025.ser 

53 msg0026.ser 

91 msg0027.ser 
57 msg0028.ser 
71 msg0029.ser 

54 msg0030.ser 
71 msg0031.ser 
54 msg0032 . ser 
86 msg0033.ser 
54 msg0034 . ser 

156 msg0035.ser 
54 msg0036.ser 

92 msg0037.ser 
54 msg0038.ser 

157 msg0039. ser 

53 msg0040.ser 
91 msg0041.ser 
57 msg0042.ser 
71 msg0043.ser 

54 msg0044 . ser 
71 msg0045.ser 
54 msg0046. ser 
86 msg0047 . ser 
54 msg0048 . ser 

121 msg0049.ser 
145 msgOOSO . ser 
75 msgOOSl.ser 

93 msg0052.ser 
4,895 bytes 



Directory of E : \e-speak-src_991217 \platf orm\ES\src\python\pyesi\abi\m 
sg\CVS 



12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:22p 

12/16/99 06:22p 

12/16/99 06:22p 

12/16/99 06:22p 



<DIR> 
<DIR> 



2,499 Entries 
52 Repository 
4 6 Root 
84 6 Template 
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6 File(s) 



test 
3,443 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\python\pyesi\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
06:22p 

7 File(s) 



<DIR> 
<DIR> 



98 Entries 
52 Entries. Log 
44 Repository 
4 6 Root 
84 6 Template 
1,086 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\python\pyesi\io 



12/06/00 
12/06/00 
12/07/99 
^12/07/99 
;%2/07/99 
>J 12/07/99 
: l 12/06/00 
™12/07/99 
^12/07/99 
!| 12/07/99 
•"12/07/99 
".12/07/99 
;r;i2/07/99 
Jfl2/07/99 
3*12/07/99 
*fl2/07/99 
2fl2/07/99 
='12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:2 6p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 



<DIR> 
<DIR> 



<DIR> 



6,758 array_buf fer.py 

3,326 buf fered_output_stream.py 

2,691 console__output_stream.py 

2,762 console_input_stream.py 
CVS 

7,225 data_input_stream.py 

9,129 data_output_stream.py 

5,7 92 demultiplexer .py 

2,668 error_output_stream. py 

4,906 file.py 

3,843 f ile_append_stream. py 

3,453 f ile_input_stream. py 

3,695 f ile_output_stream. py 

2,704 f ilter_output_stream. py 

2,678 f ilter_input_stream.py 

6,055 input_stream.py 

4,126 message_copier .py 

4,358 message_output_stream. py 

3,948 message_input_stream.py 

4,315 multiplex_output_stream. py 

4,087 mult iplex_input_st ream. py 

6,477 output_stream.py 

3,535 queue_output_stream. py 

3,579 queue_input_stream. py 

4,4 94 router. py 

4,713 rout ing_output_st ream. py 

4,239 routing_input_stream.py 
3, 4 66 string_buf f er_output_stream.py 

3, 646 string_buf fer_input_stream.py 

8,115 string_buf f er . py 

0 init .py 
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33 File(s) 



test 
130,783 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\python\pyesi\io\CV 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04 :33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
6 



<DIR> 
<DIR> 



File (si 



1,724 Entries 
47 Repository 
4 6 Root 
84 6 Template 
2,663 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\python\pyesi\net 



12/06/00 
12/06/00 
.12/07/99 
'12/06/00 
112/07/99 
il2/07/99 
:i2/07/99 
112/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
13 



<DIR> 
<DIR> 

<DIR> 



File (s) 



14,763 client_socket . py 
CVS 

9,316 http_client_stream.py 
5,148 server_socket .py 
4,848 simple_server .py 
3,62 6 simple_handler . py 
3,266 socket_output_stream.py 
3,294 socket_input_stream.py 
4,710 threaded_server .py 
2,562 threaded_handler . py 

0 init .py 

51,533 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\python\pyesi\net\C 
VS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 



<DIR> 
<DIR> 



6 File(s) 



552 Entries 
48 Repository 
4 6 Root 

84 6 Template 
1,492 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\python\pyesi\util 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 



<DIR> 
<DIR> 
<DIR> 



CVS 

10,033 file_observer.py 
16,433 f ile_queue . py 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
10 



File(s) 



test 

8,638 log.py 

3,565 thread_pool .py 

3,039 timestamp.py 

6,417 url.py 

0 init .py 

48,125 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\python\pyesi\util\ 
CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 



<DIR> 
<DIR> 



6 File(s) 



340 Entries 
4 9 Repository 
4 6 Root 

84 6 Template 
1,281 bytes 



Directory of E:\e-speak-src_991217\platform\ES\tutorial 



!l2/06/00 
;i2/06/00 
[12/06/00 
!l2/07/99 
" 12/06/00 
"12/06/00 



04:33p 
04:33p 
04:33p 
04:26p 
04:33p 
04:33p 
6 



<DIR> 
<DIR> 
<DIR> 

<DIR> 
<DIR> 



File (s) 



CVS 

225 Makefile 

sharebroker 
usedcarsale 
225 bytes 



Directory of E:\e-speak-src_991217\platform\ES\tutorial\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:23p 
06:22p 
06:22p 
06:22p 



<DIR> 
<DIR> 



7 File(s) 



48 Entries 
42 Entries. Log 
36 Repository 
4 6 Root 
84 6 Template 
1,018 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker 



12/06/00 
12/06/00 
12/07/99 
12/06/00 
12/06/00 
12/06/00 
12/07/99 



04:33p 
04:33p 
04:26p 
04:33p 
04:33p 
04:33p 
04:26p 



<DIR> 
<DIR> 

<DIR> 
<DIR> 
<DIR> 



459 compile.bat 
conf ig 
CVS 
doc 

296 Makefile 



Page 111 



test 

12/07/99 04:26p 2,040 setenv 

12/07/99 04:26p 1,416 setenv.bat 

12/06/00 04:33p <DIR> src 

10 File(s) 4,211 bytes 

Directory of E : \e-speak-src_9 91217 \platform\ES\ tut or ial\sharebroker\< 



onf ig 










12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


:33p 


<DIR> 


CVS 


12/06/00 


04 


: 33p 


<DIR> 


example 1 


12/06/00 


04 


: 33p 


<DIR> 


example2 


12/06/00 


04 


: 33p 


<DIR> 


example3 


12/06/00 


04 


:33p 


<DIR> 


example 4 


12/06/00 


04 


:33p 


<DIR> 


example 5 






8 


File(s) 


0 bytes 



I Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\ 
*onfig\CVS 

{12/06/00 04:33p <DIR> 
jl2/06/00 04:33p <DIR> 

.12/16/99 06:22p 3 Entries 

fl2/16/99 06:22p 90 Entries. Log 

? 12/16/99 06:22p 55 Repository 

.,12/16/99 06:22p 46 Root 

■12/16/99 06:22p 846 Template 

■( 7 File(s) 1,040 bytes 

I Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\ 
J onf ig\examplel 



12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 






12/07/99 


04 


:26p 




20 


bank.pr 


12/07/99 


04 


:26p 




261 


bankvocab . ini 


12/07/99 


04 


:2 6p 




1,247 


BankVocabulary . xml 


12/06/00 


04 


:33p 


<DIR> 




CVS 


12/07/99 


04 


:26p 




70 


runbankvocab . bat 


12/07/99 


04 


:26p 




61 


runbankvocab . sh 


12/07/99 


04 


:26p 




110 


runvocabf inder . bat 


12/07/99 


04 


:26p 




100 


runvocabf inder . sh 






10 File 


(s) 


1,869 bytes 



Directory of E: \e-speak-src_991217\platform\ES\tutorial\sharebroker\ 
onf ig\examplel\CVS 
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12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:22p 

12/16/99 06:22p 

12/16/99 06:22p 

12/16/99 06:22p 

6 File(s) 



test 

<DIR> 
<DIR> 

366 Entries 
64 Repository 
4 6 Root 

84 6 Template 
1,322 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\ 
onf ig\example2 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/07/99 04:26p 290 bank.ini 

12/07/99 04:26p 18 bank.pr 

12/07/99 04:26p 1,322 BankService . xml 

12/07/99 04:26p 1,247 BankVocabulary . xml 

_12/06/00 04:33p <DIR> CVS 

%2/07/99 04:26p 65 runbankservice.bat 

%2/07/99 04:26p 90 runbankservice . sh 

%2/07/99 04:26p 107 runclient.bat 

^12/07/99 04:26p 98 runclient.sh 

jjj 11 File(s) 3,237 bytes 

5 f Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\ 
* "onf ig\example2 \CVS 

t 12/06/00 04:33p <DIR> 

| ; 12/06/00 04:33p <DIR> 

"{12/16/99 06:22p 407 Entries 

-12/16/99 06:22p 64 Repository 

£12/16/99 06:22p 46 Root 

^12/16/99 06:22p 846 Template 

6 File(s) 1,363 bytes 



Directory of E: \e-speak-src_991217\platform\ES\tutorial\sharebroker\ 
onf ig\example3 



12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


:33p 


<DIR> 






12/07/99 


04 


:26p 




6 


account .dat 


12/07/99 


04 


:26p 




314 


addfunds . gif 


12/07/99 


04 


:26p 




1, 097 


add share.gif 


12/07/99 


04 


:26p 




18 


bank. pr 


12/07/99 


04 


:26p 




1,322 


BankService . xml 


12/07/99 


04 


:26p 




1,247 


BankVocabulary . xml 


12/07/99 


04 


:26p 




1,091 


buy .gif 


12/07/99 


04 


:26p 




131 


cancelord. gif 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
"112/07/99 
1112/07/99 
^12/07/99 
4ll2/07/99 
112/07/99 
'^12/07/99 
1-12/07/99 
^12/07/99 
'* 12/07/99 
^12/07/99 
] J 12/07/99 



04:26p 
04:26p 
04:26p 
04:26p 

04:33p <DIR> 

04:26p 

04:26p 

04:26p 

04:26p 

04 :26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

39 File(s) 



2j Directory of E:\e-speak-src_ 
: ^onf ig\example3\CVS 



test 

260 change_dir.gif 
254 connect.gif 
330 cpwd.gif 
320 create_vb.gif 
CVS 

131 delete.gif 
182 disconnect.gif 
275 download.gif 
110 folder.gif 
174 help.gif 
423 localserver.ini 
300 login.gif 
1,189 open_act.gif 
213 reconnect.gif 
72 runserver.bat 
130 runserver.sh 
1,094 sell.gif 

918 ShareBrokerVocabulary . xml 
1,178 ShareBrokerService.xml 
95 starttrader . sh 
71 stocktrade.bat 
1,170 title.gif 

20 trader. pro 
1,335 Trader. xml 

20 traderlntf .pro 
1,253 TraderVocabulary.xml 
1,118 TraderService . xml 
314 upload.gif 
285 watch.gif 
18,460 bytes 

991217\platform\ES\tutorial\sharebroker\c 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 

6 File(s) 



<DIR> 
<DIR> 



1,787 Entries 
64 Repository 
46 Root 
84 6 Template 
2,743 bytes 



Directory of E: \e-speak-src_991217\platform\ES\tutorial\sharebroker\c 
onf ig\example4 



12/06/00 04:33p 
12/06/00 04:33p 
12/07/99 04:26p 



<DIR> 
<DIR> 



6 account.dat 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
12/06/00 
SI12/07/99 
012/07/99 
"112/07/99 
#12/07/99 
^12/07/99 
?1 12/07/99 
^12/07/99 
^12/06/00 
12/07/99 
f:i2/07/99 
±12/07/99 
^12/07/99 
|l2/07/99 
;I?12/07/99 



04:26p 
04:26p 
04 :26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04 : 33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:33p 
04:33p 
04:26p 
04 :26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04 : 26p 
04:26p 
04:26p 

35 File(s) 



test 

314 addfunds.gif 
1,097 add_share.gif 
1,4 44 BankService . xml 
1,362 BankVocabulary.xml 
1,091 buy.gif 

131 cancelord.gif 
260 change_dir.gif 
254 connect.gif 
330 cpwd.gif 
320 create_vb.gif 
<DIR> CVS 

131 delete.gif 
182 disconnect.gif 
275 download.gif 
110 folder.gif 
174 help.gif 
<DIR> hostl 
<DIR> host2 

300 login.gif 
1,189 open_act.gif 

213 reconnect.gif 
1,094 sell.gif 

1,485 ShareBrokerVocabulary.xml 

1.429 ShareBrokerService2 . xml 

1.430 ShareBrokerServicel .xml 
<DIR> singlehost 

1,170 title.gif 
1,335 Trader. xml 
1,253 TraderVocabulary.xml 
1,118 TraderService.xml 
314 upload.gif 
285 watch.gif 
20,096 bytes 



Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\c 
onf ig\example4 \CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:'33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
06:22p 
7 



<DIR> 
<DIR> 



File (s) 



1,453 Entries 

50 Entries. Log 
64 Repository 
4 6 Root 
84 6 Template 
2,459 bytes 



Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\c 
onf ig\example4\hostl 
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test 



12/06/00 


04 


:33p <DIR> 






12/06/00 


04 


:33p <DIR> 






12/07/99 


04 


: 26p 


141 


bank.pr 


12/07/99 


04 


: 26p 


22 


col 


12/06/00 


04 


:33p <DIR> 




CVS 


12/07/99 


04 


:26p 


114 


runbrokerl . bat 


12/07/99 


04 


:26p 


138 


runbrokerl . sh 


12/07/99 


04 


:26p 


73 


sharebrokerl . bat 


12/07/99 


04 


:26p 


672 


sharebrokerl . ini 


12/07/99 


04 


:26p 


304 


sharebrokerl . pr 


12/07/99 


04 


:26p 


158 


sharebrokerl . sh 


12/07/99 


04 


:26p 


139 


stocktrade.pr 






12 File(s) 


1,761 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\c 
onfig\example4\hostl\CVS 



=112/06/00 04:33p 

$12/06/00 04:33p 

^12/16/99 06:22p 

4112/16/99 06:22p 

■ #12/16/99 06:22p 

$12/16/99 06:22p 

II 6 File(s) 



<DIR> 
<DIR> 



448 Entries 
70 Repository 
4 6 Root 
846 Template 
1,410 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\c 
"onf ig\example4\host2 



! 12/06/00 
■12/06/00 
j 12/07/99 
1 12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:33p 
04 :26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
12 



<DIR> 
<DIR> 



<DIR> 



File (si 



141 bank.pr 

22 co2 
CVS 

115 runbroker2.bat 
137 runbroker2. sh 

73 sharebroker2.bat 
730 sharebroker2.ini 
302 sharebroker2.pr 
177 sharebroker2 . sh 
139 stocktrade.pr 
1,836 bytes 



Directory of E: \e-speak-src_991217 \platf orm\ES\ tutor ial\sharebr oker\c 
onfig\example4\host2\CVS 



12/06/00 04:33p 
12/06/00 04:33p 



<DIR> 
<DIR> 
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test 

12/16/99 06:22p 448 Entries 

12/16/99 06:22p 70 Repository 

12/16/99 06:22p 46 Root 

12/16/99 06:22p 846 Template 

6 File(s) 1,410 bytes 

Directory of E : \e-spea k-src_9 9121 7 \platform\ES\ tutor ial\sharebroker\c 
onf ig\example4\singlehost 



12/06/00 


04 


:33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 






12/07/99 


04 


:26p 




43 


bank. pr 


12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/07/99 


04 


:26p 




549 


localserver . ini 


12/07/99 


04 


:26p 




115 


runbroker2 . bat 


12/07/99 


04 


:26p 




115 


runbrokerl . bat 


12/07/99 


04 


:26p 




72 


runserver .bat 


12/07/99 


04 


:26p 




206 


sharebroker2 . pr 


Q12/07/99 


04 


:26p 




207 


sharebrokerl .pr 


.£12/07/99 


04 


:26p 




71 


stocktrade . bat 


%1 12/07/ 99 


04 


:26p 




43 


stocktrade.pr 



M 12 File(s) 1,421 bytes 

ft Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\ 
Ijonf ig\example4\singlehost\CVS 

i 12/0 6/00 04:33p <DIR> 
•'12/06/00 04:33p <DIR> 

1112/16/99 06:22p 456 Entries 

312/16/99 06:22p 75 Repository 

1112/16/99 06:22p 46 Root 

SI12/16/99 06:22p 846 Template 

3 6 File(s) 1,423 bytes 



Directory of E: \e-speak-src_9 912 17 \platform\ES\ tutorial \sharebroker\ 
onf ig\example5 



12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 






12/07/99 


04 


:26p 




6 


account . dat 


12/07/99 


04 


:26p 




314 


addf unds . gif 


12/07/99 


04 


:26p 




1,097 


add_share . gif 


12/07/99 


04 


:26p 




43 


bank.pr 


12/07/99 


04 


:26p 




1, 444 


BankService . xml 


12/07/99 


04 


:26p 




1,362 


BankVocabulary . xml 


12/07/99 


04 


:26p 




1,091 


buy . gif 


12/07/99 


04 


: 26p 




131 


cancelord.gif 


12/07/99 


04 


:26p 




260 


change dir. gif 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
112/07/99 
J12/07/99 
J12/07/99 
,112/07/99 
J12/07/99 
112/07/99 
J12/07/99 
-*12/07/99 
12/07/99 
v *12/07/99 
U12/07/99 
112/07/99 
ai2/07/99 
112/07/99 
112/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:26p 
04:26p 
04:26p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04 :26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 



test 

18 cleandb.bat 
254 connect.gif 
330 cpwd.gif 
320 create_vb.gif 
<DIR> CVS 

131 delete.gif 
8,405 demoexample5.html 
182 disconnect.gif 
275 download.gif 
110 folder.gif 
174 help.gif 
5,687 Imagel.gif 
5,889 Imagel0.gif 
17,709 Imagell.gif 
13,800 Imagel2.gif 
13,686 Imagel3.gif 

9,041 Image2.gif 
11,845 Image3.gif 
11,859 Image4.gif 
10,472 Image5.gif 
12,712 Image6.gif 
9,852 image7.gif 
9,634 Image9.gif 
41,855 imageUUV.gif 
551 localserver.ini 
300 login.gif 
1,189 open_act.gif 
5, 522 README_EXAMPLE5 . txt 
213 reconnect.gif 
115 runbroker2.bat 
115 runbrokerl.bat 
72 runserver.bat 
10,163 sample . j serv. properties 
1,094 sell.gif 

72 sharebroker.bat 

206 sharebroker2 . pr 

20 shareBrokerlntf .pro 

1.429 ShareBrokerService2 . xml 

207 sharebrokerl .pr 

1.430 ShareBrokerServicel . xml 
1,485 ShareBrokerVocabulary . xml 

71 stocktrade.bat 
68 9 StockTrade.html 

43 stocktrade.pr 
1,170 title.gif 

43 trader. pro 
1,335 Trader. xml 

20 traderlntf .pro 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:26p 
04:26p 
04:26p 
04:26p 

63 File(s) 



test 

1,253 TraderVocabulary . xml 
1,118 TraderService . xml 

314 upload.gif 

285 watch.gif 
220,512 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\c 
onf ig\example5\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
6 



<DIR> 
<DIR> 



File (s! 



2,999 Entries 
64 Repository 
46 Root 
846 Template 
3, 955 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\C 
VS 



112/06/00 
J12/06/00 
112/16/99 
112/16/99 
112/16/99 
=12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:23p 
06: 22p 
06:22p 
06:22p 



<DIR> 
<DIR> 



7 File(s) 



186 Entries 
42 Entries. Log 
48 Repository 
4 6 Root 

846 Template 
1,168 bytes 



I Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\d 
Joe 

112/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 1,806,132 ShareBrokerDocs.zip 

4 File(s) 1,806,132 bytes 

Directory of E: \e-speak-src_991217\platform\ES\tutorial\sharebroker\d 
oc\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:23p 
06:22p 
06:22p 
06:22p 



<DIR> 
<DIR> 



6 File(s! 



59 Entries 
52 Repository 
4 6 Root 
84 6 Template 
1,003 bytes 
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test 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\s 
rc 



12/06/00 


04: 


33p 


<DIR> 




12/06/00 


04: 


33p 


<DIR> 




12/06/00 


04: 


33p 


<DIR> 


CVS 


12/06/00 


04: 


33p 


<DIR> 


example 1 


12/06/00 


04: 


33p 


<DIR> 


example2 


12/06/00 


04: 


33p 


<DIR> 


example 3 


12/06/00 


04: 


33p 


<DIR> 


example 4 


12/06/00 


04: 


33p 


<DIR> 


example 5 






8 


File (s) 


0 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\s 
rc\CVS 



12/06/00 


04:33p 


<DIR> 






,«* 12/06/00 


04:33p 


<DIR> 






112/16/99 


06:23p 




3 


Entries 


*!l2/16/99 


06:23p 




90 


Entries .Log 


,112/16/99 


06:23p 




52 


Repository 


m 12/16/99 


06:23p 




46 


Root 


'$12/16/99 


06:23p 




846 


Template 



7 File(s) 1,037 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\s 



rc\examplel 






*|12/06/00 


04:33p 


<DIR> 




S 12/06/00 


04:33p 


<DIR> 




312/07/99 


04:26p 




4,723 BankVocabulary . java 


512/07/99 


04:26p 




4,109 BankVocabFinder . java 


'"12/07/99 


04:26p 




353 compile.bat 


12/06/00 


04:33p 


<DIR> 


CVS 


12/07/99 


04:26p 




361 Makefile 




7 


File (s) 


9,546 bytes 



Directory of E : \e- speak- src_9 9 12 17 \platform\ES\ tutorial \sharebroker\s 
rc\examplel\CVS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:23p 209 Entries 

12/16/99 06:23p 61 Repository 

12/16/99 06:23p 46 Root 

12/16/99 06:23p 846 Template 

6 File(s) 1,162 bytes 
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Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\ 
rc\example2 



12/06/00 


04 


:33p 


<DIR> 








12/06/00 


04 


: 33p 


<DIR> 








12/07/99 


04 


:27p 




3, 


326 


AccountNumberGenerator . j ava 


12/07/99 


04 


:27p 




1, 


930 


Address . esidl 


12/07/99 


04 


:27p 

XT 




6, 


326 


BankClient . j ava 


12/07/99 


04 


:27p 




2, 


748 


BankServicelntf . esidl 


12/07/99 


04 


:27p 




3, 


192 


BankServicelntf Finder . java 


12/07/99 


04 


:27p 




15, 


603 


BankServicelmpl . java 


12/07/99 


04 


:27p 




4, 


094 


BankService . j ava 


12/07/99 


04 


:27p 




4, 


731 


BankVocabulary . j ava 


12/07/99 


04 


:27p 




1, 


823 


Company .esidl 


12/07/99 


04 


:27p 






491 


compile .bat 


12/06/00 


04 


: 33p 


<DIR> 






CVS 


12/07/99 


04 


:27p 




1, 


007 


Makefile 


r?|12/07/99 


04 


:27p 




2, 


063 


OrderDetailParam. esidl 


312/07/99 


04 


:27p 




2, 


275 


Semaphore .java 


^12/07/99 


04 


:27p 




2, 


003 


ShareDetailParam. esidl 


UI12/07/99 


04 


:27p 




3, 


223 


ShareDetail .java 


tf!2/07/99 


04 


:27p 




2, 


461 


UserAccount . j ava 



19 File(s) 57,296 bytes 



U Directory of E:\e-speak-src__991217\platform\ES\tutorial\sharebroker\ 
u rc\example2\CVS 



1112/06/00 


04:33p <DIR> 




□12/06/00 


04:33p <DIR> 




112/16/99 


06:23p 


874 Entries 


312/16/99 


06:23p 


61 Repository 


312/16/99 


06:23p 


46 Root 


12/16/99 


06:23p 


84 6 Template 




6 File(s) 


1,827 bytes 



Directory of E: \e-speak-src__991217\platf orm\ES\tutorial\sharebroker\ 
rc\example3 



12/06/00 


04 


:33p 


<DIR> 




12/06/00 


04 


:33p 


<DIR> 




12/07/99 


04 


:27p 


3, 325 


AccountNumberGenerator . j ava 


12/07/99 


04 


:27p 


5,773 


AddFundsGUI . j ava 


12/07/99 


04 


:27p 


1, 930 


Address . esidl 


12/07/99 


04 


:27p 


8,140 


AddSharesGUI . j ava 


12/07/99 


04 


:27p 


10,909 


AuthorizationWindow. java 


12/07/99 


04 


:27p 


2,783 


BankServicelntf . esidl 


12/07/99 


04 


:27p 


3,119 


BankServicelntf Finder . java 
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test 




12/07/99 


04 


:27p 


14,971 


BankServicelmpl . j ava 


12/07/99 


04 


:27p 


4,083 


BankService . j ava 


12/07/99 


04 


:27p 


4,723 


BankVocabulary . j ava 


12/07/99 


04 


:27p 


18,119 


BrokerLogic . j ava 


12/07/99 


04 


:27p 


10,571 


BuySharesGUI . j ava 


12/07/99 


04 


:27p 


7,170 


ChangePasswordGUI . java 


12/07/99 


04 


:27p 


1, 819 


Company. esidl 


12/07/99 


04 


:27p 


689 


compile . bat 


12/06/00 


04 


:33p 


<DIR> 


CVS 


12/07/99 


04 


:27p 


9,308 


ListAccountGUI . j ava 


12/07/99 


04 


:27p 


18, 944 


ListSharesGUI . java 


12/07/99 


04 


:27p 


7, 871 


LoginGUI . j ava 


12/15/99 


04 


:00p 


2,405 


Makefile 


12/07/99 


04 


:27p 


1, 901 


MatchThread . j ava 


12/07/99 


04 


:27p 


5,656 


MessageDialog. java 


12/07/99 


04 


:27p 


7,592 


OpenAccountGUI . j ava 


12/07/99 


04 


:27p 


2,063 


OrderDetailParam. esidl 


12/07/99 


04 


:27p 


3, 610 


OrderDetail . j ava 


,-•12/07/99 


04 


:27p 


9, 686 


SellSharesGUI .java 


!ll2/07/99 


04 


:27p 


2,279 


Semaphore . j ava 


V12/07/99 


04 


:27p 


2, 650 


ServiceDeployer . java 


42/07/99 


04 


:27p 


2,225 


ShareBrokerlntf . esidl 


1112/07/99 


04 


:27p 


3,256 


ShareBrokerlnt f Finder . j ava 


312/07/99 


04 


:27p 


4, 600 


ShareBrokerlmpl . j ava 


1112/07/99 


04 


:27p 


2,046 


ShareDetailParam. esidl 


,.12/07/99 


04 


:27p 


3,223 


ShareDetail . j ava 


,12/07/99 


04 


:27p 


4,449 


StartShareBrokerService . java 


1,12/07/99 


04 


:27p 


6, 322 


StartTraderService . j ava 


1112/07/99 


04 


:27p 


23,802 


StockTrade . j ava 


C12/07/99 


04 


:27p 


1, 921 


TraderQuerySpec. esidl 


1312/07/99 


04 


:27p 


4,840 


TraderVocabulary . j ava 


13.2/07/99 


04 


:27p 


1, 948 


Traderlntf. esidl 


if.2/07/99 


04 


:27p 


2,731 


TraderService . j ava 


"12/07/99 


04 


:27p 


4,384 


Traderlntf Finder . j ava 


12/07/99 


04 


:27p 


2, 979 


Traderlmpl . j ava 


12/07/99 


04 


:27p 


1,969 


Transaction. esidl 


12/07/99 


04 


:27p 


2,459 


UserAccount . j ava 



46 File(s) 245,243 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\s 
rc\example3\CVS 



12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:23p 

12/16/99 06:23p 

12/16/99 06:23p 

12/16/99 06:23p 



<DIR> 
<DIR> 



2,389 Entries 
61 Repository 
4 6 Root 
846 Template 
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6 File(s) 



test 
3,342 bytes 



Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\s 



rc\example4 








i 9 /o £ /oo 

XZ / UD / UU 


0 4 


: 33p 


<DIR> 




i 9 /o 6 /oo 

X ^- / U U / U U 


04 

U ft 


: 33p 


<DIR> 




1 9 /Q7 /QQ 


04 

U *3 


:27p 


3, 407 


AccountNumberGenerator . java 


1 9 /07 /QQ 

X Z. / U / / 


04 
u ft 


:27p 


5,829 


AddFundsGUI .java 


XZ / U / / _7 Z7 


04 
U ft 


:27p 


1, 930 


Address . esidl 


1 9 /07 /QQ 


04 

U f± 


:27p 


8,196 


AddSharesGUI . j ava 


1 9 /07 / Q Q 

XZ/U//:7_7 


04 

U ft 


:27p 


10,880 


Authori zationWindow . j ava 


1 o /07 / QQ 
1Z/ u / / 


O A 
U 4 


:27p 


2,783 


BankServicelntf . esidl 


izv u / / y y 


U4 


:27p 


6,052 


BankServicelntf Finder . java 


1 9 /07 / QQ 


O A 
u 4 


:27p 


17,695 


BankServicelmpl . j ava 


no /n7 / QQ 


U 4 


:27p 


4, 392 


BankService . j ava 


19 /07 / QQ 
1Z/U i / yy 


U 4 


:27p 


4,718 


BankVocabulary. java 


1 9 /07 / QQ 
±<l / \J 1 / yy 


U 4 


:27p 


33, 103 


BrokerLogic . j ava 


■ 19 /H7 / QQ 

r-; : ; x Z / U I f yy 


U 4 


:27p 


10,530 


BuySharesGUI . java 


'^1 9 / n 7 / Q Q 


0 A 
U 4 


:27p 


5, 975 


CancelOrderGUI . java 


""l 9 / n 7 / Q Q 
%jlz / U I / yy 


U 4 


:27p 


7,389 


ChangePasswordGUI . j ava 


; si 9 / Pi 7 / Q Q 
jjJxZ / \) l ( yy 


O A 
U 4 


:27p 


1,819 


Company . esidl 


S<\ 9/07/QQ 

: e|X Z / U / / _7 _? 


0 4 

U fi 


:27p 


691 


compile .bat 


9 /0£ / on 

: J sX Z / UD / UU 


0 4 


: 33p 


<DIR> 


CVS 


5 n 9/07/QQ 


0 4 

U *i 


:27p 


2, 049 


Helper . j ava 


\ Yl 9 / n 7 / Q Q 

;^?xz / u / / y y 


0 4 

U ft 


:27p 


9,303 


ListAccountGUI . j ava 


1 9 /07 / QQ 


04 
U ft 


:27p 


6,758 


ListBanksGUI . j ava 


2 / 07 / 99 


04 


:27p 


7,518 


ListBrokersGUI .java 


\%n 9 / n 7 / QQ 
i ^^x z / u i f yy 


04 
U ft 


:27p 


18, 889 


ListSharesGUI . java 


9/07/QQ 


04 
u ft 


:27p 


7, 920 


LoginGUI . java 


;ff] 9/1 S / q q 


04 

U 4 


:00p 


2,835 


Makefile 


r-tl 9/07 /99 


04 


:27p 


1, 901 


MatchThread . j ava 


i^^l 9 / 0 7 / Q Q 


n a 

U 4 


:27p 


5, 657 


MessageDialog. java 


1 9/07/QQ 


U H 


:27p 


3,255 


MessageClient . java 


12/07 /99 


04 


:27p 


7, 618 


OpenAccountGUI . j ava 


12/07/99 


04 


:27p 


2,065 


OrderDetailParam. esidl 


12/07/99 


04 


:27p 


3, 178 


OrderDetail . java 


12/07/99 


04 




9 O^/l 
Z f UD4 


Keq/\utninreaa. j ava 


12/07/99 


04 


:27p 


7,236 


SelectBankGUI . j ava 


12/07/99 


04 


: 27p 


9, 890 


SellSharesGUI .java 


12/07/99 


04 


: 27p 


2,277 


Semaphore . j ava 


12/07/99 


04 


:27p 


3,005 


ServiceDeployer . j ava 


12/07/99 


04 


:27p 


2,537 


ShareBrokerlntf. esidl 


12/07/99 


04 


:27p 


6, 943 


ShareBrokerlntf Finder . j ava 


12/07/99 


04 


:27p 


6, 917 


ShareBrokerlmpl . j ava 


12/07/99 
a 


04 


:27p 


2,259 


ShareBrokerEventDistributor . jav 


12/07/99 


04 


:27p 


2, 048 


ShareDetailParam. esidl 
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test 



12/07/99 


04 


:27p 


3,226 


ShareDetail . j ava 


12/07/99 


04 


:27p 


6, 678 


StartShareBrokerService . j ava 


12/07/99 


04 


:27p 


6,346 


StartTraderService . j ava 


12/07/99 


04 


:27p 


5,204 


StatusWindow. java 


12/07/99 


04 


:27p 


26, 825 


StockTrade . j ava 


12/07/99 


04 


:27p 


1,946 


TraderQuerySpec . esidl 


12/07/99 


04 


:27p 


3,929 


Traderlntf Finder . j ava 


12/07/99 


04 


:27p 


" 080 


Trader Intf .esidl 


12/07/99 


04 


:27p 


3,774 


Traderlmpl . java 


12/07/99 


04 


:27p 


5,030 


TraderVocabulary. java 


12/07/99 


04 


:27p 


2, 730 


TraderService . java 


12/07/99 


04 


:27p 


1, 969 


Transaction . esidl 


12/07/99 


04 


:27p 


2, 461 


UserAccount . j ava 






55 File(s) 


321, 69S 


) bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\s 
rc\example4\CVS 



■ ,12/06/00 04:33p <DIR> 

^12/06/00 04:33p <DIR> 

"12/16/99 06:23p 2,891 Entries 

UJ12/16/99 06:23p 61 Repository 

iijl2/16/99 06:23p 46 Root 

,$12/16/99 06:23p 846 Template 

fff 6 File(s) 3, 844 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\ tutorial \sharebroker\s 



Urc\example5 




gl2/06/00 


04 


:33p 


M12/06/00 


04 


:33p 


£112/07/99 


04 


:27p 


-112/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27 P 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 



<DIR> 
<DIR> 



3,408 AccountNumberGenerator . java 

5,120 AddFundsGUI. java 

2,629 AddFundServlet . java 

1,932 Address . esidl 

3,248 AddSharesServlet . java 

7,505 AddSharesGUI. java 

11,907 AuthorizationWindow. java 

3,87 0 AuthoriseOrderServlet . java 

2,783 BankServicelntf .esidl 

9,119 BankServicelntf Finder . java 

17, 380 BankServicelmpl . java 

4,436 BankService. java 

4,907 BankVocabulary. java 

33,34 6 BrokerLogic. java 

3,346 BuySharesServlet . java 

9,070 BuySharesGUI. java 

2,443 CancelOrderServlet . java 
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12/07/99 


04 


:27p 


12/07/99. 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/06/00 


04 


: 33p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


,,,12/07/99 


04 


:27p 


1:12/07/99 


04 


:27p 


?{l2/07/99 


04 


:27p 


."12/07/99 


04 


:27p 


^12/07/99 


04 


:27p 


&2/07/99 


04 


:27p 


IJ12/15/99 


04 


: OOp 


$.2/07/99 


04 


:27p 


7 12/07/99 


04 


:27p 


i K d2/07/99 


04 


:27p 


ml2/07/99 


04 


:27p 


;=ft.2/07/99 


04 


:27p 


&2/07/99 


04 


:27p 


-112/07/99 


04: 


:27p 


=12/07/99 


04: 


:27p 


"12/07/99 


04 : 


:27p 


12/07/99 


04 : 


:27p 


12/07/99 


04: 


:27p 


12/07/99 


04: 


:27p 


12/07/99 


04: 


:27p 


12/07/99 


04: 


:27p 


12/07/99 


04: 


:27p 


12/07/99 


04: 


:27p 


12/07/99 


04: 


:27p 


12/07/99 


04: 


:27p 


12/07/99 


04: 


:27p 


12/07/99 


04: 


27p 


12/07/99 


04: 


27p 


12/07/99 


04: 


27p 



test 

5,803 CancelOrderGUI. java 
2,131 ChangePasswordServlet . java 
7,361 ChangePasswordGUI . java 
3,881 CheckSharesThread. java 
3,012 CheckSharesServlet . java 
1,823 Company. esidl 

689 compile.bat 
2, 020 Connect ionClass . java 
<DIR> CVS 

2,536 Encoder. java 

1. 890 GetShareBrokerListServlet . java 
2,049 Helper. java 

2, 621 ListAccountSharesServlet . java 
8,67 9 ListAccountGUI. java 
2, 571 ListAccountBalanceServlet .java 
7,471 ListBanksGUI. java 
2,588 ListBanksServlet . java 
2,775 ListBrokersServlet . java 
8,108 ListBrokersGUI. java 
3,201 ListSharesServlet . java 
17,095 ListSharesGUI. java 
5,735 ListShareBrokersGUI . java 
7,521 LoginGUI . java 
2,501 LoginServlet . java 
3,091 Makefile 
1,901 Mat chThread. java 
2,122 MessageDump. java 
5,678 MessageDialog. java 
4,084 MessageClient . java 
5,908 Message. java 
2,662 OpenAccountServlet . java 
8,990 OpenAccountGUI. java 
2,106 OrderCollection. java 

2.064 OrderDetailParam. esidl 
3,182 OrderDetail . java 

1.891 QuerySpec. esidl 

2.65 9 QuerySpec. java 
2,054 ReqAuthThread. java 
7,129 SelectBankGUI. java 
3,215 SellSharesServlet . java 
8,402 SellSharesGUI. java 
2,27 5 Semaphore. java 

2,598 ServiceDeployer . java 

2,535 ShareBrokerlntf .esidl 

9,723 ShareBrokerlntf Finder . java 

7,299 ShareBrokerlmpl. java 

2, 261 ShareBrokerEventDistributor . jav 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04 :27p 

81 File(s) 



test 

2,045 ShareDetailParam. esidl 

3,565 ShareDetail . java 

6,741 Start ShareBroker Service .java 

5,365 StartTraderServiceServlet .java 

3,254 StartTraderService . java 

4,708 StatusWindow. java 
29,153 StockTrade. java 

1,945 TraderQuerySpec. esidl 

5,059 TraderVocabulary . java 

2,078 Traderlntf .esidl 

2,729 TraderService. java 

3,944 Traderlntf Finder. java 

3,614 Trader Impl . java 

1,986 Transaction. java 

2,545 UserAccount . j ava 
403, 670 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\s 
^rc\exaniple5\CVS 



"12/06/00 
i '!!il2/06/00 
jtt.2/16/99 
143-2/16/99 
iSi.2/16/99 
vl2/16/99 



04:33p 
04:33p 
06:23p 
06:23p 
06:23p 
06:23p 
6 



<DIR> 
<DIR> 



File(s) 



4,413 Entries 
61 Repository 
4 6 Root 
84 6 Template 
5,366 bytes 



m Directory of E:\e-speak-src_991217\platform\ES\tutorial\usedcarsale 



#5.2/06/00 


04 


: 33p 


<DIR> 






-12/06/00 


04 


: 33p 


<DIR> 






31.2/07/99 


04 


:27p 




1,208 


Carsales . ini 


"12/06/00 


04 


: 33p 


<DIR> 




conf ig 


12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/06/00 


04 


:33p 


<DIR> 




html 


12/07/99 


04 


:27p 




229 


Makefile 


12/07/99 


04 


:27p 




5, 938 


README 


12/07/99 


04 


:27p 




126 


runcore.bat 


12/07/99 


04 


:27p 




472 


runservers.bat 


12/07/99 


04 


:27p 




5,923 


sample . zone . properties 


12/07/99 


04 


:27p 




10, 177 


sample . j serv . properties 


12/06/00 


04 


: 33p 


<DIR> 




servlets 


12/07/99 


04 


:27p 




2,892 


setenv 


12/07/99 


04 


:27p 




2, 152 


setenv.bat 


12/07/99 


04 


:27p 




6 


Slides .ppt 


12/06/00 


04 


:33p 


<DIR> 




src 



17 File(s) 



29,123 bytes 
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test 



Directory of E : \e~spea k-src_9 9121 7 \platform\ES\ tutorial \usedcarsale\c 
onf ig 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
,^12/07/99 
1:12/07/99 



04:33p <DIR> 

04:33p <DIR> 

04:27p H7 

04:27p 97 

04:27p 73 

04:27p 105 

04:27p 132 

04:27p 22 

04:27p 22 

04:33p <DIR> 

04:27p 1,129 

04:27p 129 

04:27p 737 

04:27p 99 

04:27p 97 

04:27p 141 

16 File (s) 2, 900 



Buyerl.pr 
Buyer2 . pr 
CarAd.pr 
CarBroker2 .pr 
CarBrokerl .pr 
co.MYCOl 
co.MYCO 
CVS 

input .ptml 
Payment . pr 
response. ptml 
Sellerl .pr 
Seller2 .pr 
SendMailServer . pr 
bytes 



;!pnfig\CVS 






[J2/06/00 


04: 


: 33p 


. 12/06/00 


04: 


:33p 


1^12/16/99 


06: 


:23p 


Sl2/16/99 


06: 


:23p 


'42/16/99 


06: 


: 23p 


;i{L2/16/99 


06: 


:23p 
6 


Directory of E: ' 


VS 






12/06/00 


04 : 


33p 


12/06/00 


04: 


33p 


12/16/99 


06: 


23p 


12/16/99 


06: 


23p 


12/16/99 


06: 


23p 


12/16/99 


06: 


23p 


12/16/99 


06: 


23p 



<DIR> 
<DIR> 



File (s) 



621 Entries 
55 Repository 
4 6 Root 
84 6 Template 
1,568 bytes 



<DIR> 
<DIR> 



7 File(s) 



495 Entries 
61 Entries. Log 
48 Repository 
4 6 Root 

846 Template 
1,496 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\usedcarsale\h 
tml 
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f PSf 




12/06/00 


04 


•33d <DIR> 






12/06/00 


04 


•33n <DIR> 






12/07 /99 


04 


• 27n 


S 634 


rVJt. VCI LiociUOClX . IILIUX 


12/07 /99 


04 


• 9 7n 


1 R9R 


DUyCl J. _L -L O LJwl CC11 • XI UiU-i- 


1 9 /D7 /QQ 


U 4 


• 27n 

• z. / p 


9 4 R 6 




1 9 /07 /QQ 


04 

U 4 


* ir 


9 4 S 6 

Z. f 4 J U 


DuycxJjogiiii . iiLiui 


1 9 /07 /QQ 


04 

U 4 


• 97n 


1 7 R7 
X , / o / 




1 9 /07 /QQ 


04 


• 9 7r> 


9 660 


TIT 7 £2i <T T C"f~ Q V 9 Vl"i~ TTI 1 

Duyciney lSLeiz . iiliux 


1 9 /D7 /QQ 


04 

U 4 


• 97n 


9 660 


T5i i w iCi v* "D /t t c? 4" v* 1 V\ -j— tt\ 1 

Duyert\egiSLeri . rixiu-L 


12 /07 /99 


04 


* 27n 


1 878 


L/<3.i.j*jxujs.cX r JlL o Lot— xcfcrnz . 11 luix 


19/n7/QQ 

/ U i / J y 


04 

U 4 


• ?7n 


1 R 7 6 


"v^ r> -y /«i /-\ y~ IT 1 t v* <T> 4~ O >~ /"\ 1^1 I V* m ! 


19/07/QQ 
± £ / \J i f y y 


04 

U 4 


• 97r> 

* Jr 


"3 4 6Q 
o r 4 D y 


cnoiccZ . uuinx 


1 9 /fl7 /QQ 
X Z / U f / yy 


0 4 


• 97r> 

• ^ / p 


1 4 6Q 
O 7 4 O y 


cnoicei . ni-iux 


19/06/00 


04 


* 3 3d <DTR> 

• J J U \ J-^ _L i\ ^ 






1Z/ UD/ UU 


U ft 


. J jp v. UX I\/ 




liuages 


12/07 /99 


04 


* 27r> 


14 010 


n cs\jp a t~c^ 1 oo "h m 1 
IiCWL.ai oal co . IILILLX 


1 9 /07 /QQ 


04 

U 4 


• 97n 


1 P 9 4 


Ceil 1 ArPlaf d -1 1 c? l-i+--ml 


1 9 /f)7 /99 


04 


* 27n 


1 RRR 


QQ2 vr'Vi ITrivCo 1 love? 4- rn 1 


12/07/99 


04 

U 4 


• 97m 

• Z. / p 


9 4 S6 

c. f 4 O D 


CIol lovT Arri n 1 V\ 4- -m 1 

ocixeiLogiiii . nciux 


I2ln O / n 7 / QQ 
L£ f \J f f yy 


0 4 
U 4 




1 , 0 Z 


O i i r^N -v~ L ' -i -v— r~ i 4- O ^ -v* r-v y*x n V-i 4— -yv-i T 

beiieir lrstocreon . ncinx 


9 / n 7 / Q Q 


0 4 
U 4 


- 97n 
. Z. / p 




beiierKegister/ . numi 


^12/07/99 


04 


* 27n 


2, 661 


SellerRegisterl . html 


;S|L2/07/99 


04 


:27p 


1, 661 


sellerops . html 


;lfl2/07/99 


04 


:27p 


2, 458 


SellerLogin2 . html 


Iih.2/07/99 


04 


:27p 


1,343 


thanks .html 


i'12/07/99 


04 


:27p 


20,513 


webdemo . html 






26 File(s) 


83,447 bytes 



!*= Directory of E:\e-speak-src_991217\platform\ES\tutorial\usedcarsale\h 
ji|:ml\CVS 



512/06/00 


04:33p 


<DIR> 






112/06/00 


04:33p 


<DIR> 






12/16/99 


06:23p 




1,205 


Entries 


12/16/99 


06:23p 




16 


Entries .Log 


12/16/99 


06:23p 




53 


Repository 


12/16/99 


06:23p 




46 


Root 


12/16/99 


06:23p 




846 


Template 



7 File(s) 2,166 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\usedcarsale\h 
tml\ images 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:27p 
04:27p 
04:27p 



<DIR> 
<DIR> 



13,761 buy.jpg 
11,004 car3_anm.gif 
19,273 carbroker.jpg 
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12/06/00 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 



04:33p 

04:27p 

04:27p 

04:27p 

04:27p 

04:27p 

04:27p 

04:27p 

04:27p 

04:27p 

04 :27p 

04:27p 

04:27p 

04:27p 

04:27p 

04:27p 

04:27p 

04:27p 

04:27p 

24 File(s) 



<DIR> 



test 

52 
2,578 
82,264 
971 
971 
98,743 
160,012 
161,302 
110, 035 
123,161 
128, 175 
131,157 
141,087 
157, 932 
161,582 
159,451 
7, 986 
398 
1,671,895 



CVS 

espeak. JPG 
happy. gif 
interact . jpg 
left-hand. gif 
right-hand. gif 
si. jpg 
slO .jpg 
sll . jpg 
s2.jpg 
s3 . jpg 
s4.jpg 
s5 . jpg 
s6 . jpg 
s7.jpg 
s8 . jpg 
s9.jpg 
seller. jpg 
visal_60x38_a . gif 
bytes 



itmmmage^C^ 



~:12/06/00 
y 12/06/00 
' = l2/16/99 
f .12/16/99 

:;:i2/i6/99 

;jJl2/16/99 



04:33p 
04:33p 
06:23p 
06:23p 
06:23p 
06:23p 
6 



<DIR> 
<DIR> 



File (s) 



965 Entries 
60 Repository 
4 6 Root 
846 Template 
1, 917 bytes 



4rvle?s° ry ° f E:Xe " Speak " SrC - 991217X P latfor ^ ES \tutorial\usedcarsale\s 



12/06/00 
12/06/00 
12/07/99 
12/06/00 
12/15/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04 :27p 
04:33p 
04 : OOp 
04:27p 
04:27p 
04:27p 
04:27p 
9 



<DIR> 
<DIR> 

<DIR> 



File(s; 



880 compile.bat 
CVS 

663 Makefile 
4,158 Register. java 
38,178 RunCarSellerClient . java 
4 6,235 RunCarBuyerClient . java 
13,415 RunCarBrokerService. java 
103,529 bytes 



ervJets\Jvs° f E '' Xe - Speak - src - 991217 \Platf orm\ES\tutorial\usedcarsale\s 
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test 



12/06/00 


04 


: 33p 


12/06/00 


04: 


:33p 


12/16/99 


06: 


:23p 


12/16/99 


06: 


:23p 


12/16/99 


06: 


:23p 


12/16/99 


06: 


:23p 
6 


Directory of E: ' 


rc 






12/06/00 


04: 


: 33p 


12/06/00 


04: 


:33p 


12/07/99 


04: 


:27p 


12/07/99 


04: 


27p 


12/07/99 


04: 


27p 


12/07/99 


04: 


27p 


,-.12/07/99 


04: 


27p 


;i;l2/07/99 


04: 


27p 


£'12/07/99 


04: 


27p 


i!Jl2/07/99 


04: 


27p 


';1l2/07/99 


04: 


27p 


i«12/07/99 


04: 


27p 


^12/06/00 


04: 


33p 


,112/07/99 


04: 


27p 


I 12/15/99 


04: 


OOp 


U12/07/99 


04 : 


27p 


11512/07/99 


04: 


27p 


^12/07/99 


04: 


27p 


Sl2/07/99 


04 : 


27p 


ril2/07/99 


04: 


27p 


;S|12/07/99 


04: 


27p 


"'12/07/99 


04 : 


27p 


12/07/99 


04: 


27p 


12/07/99 


04: 


27p 


12/07/99 


04: 


27p 


12/07/99 


04: 


27p 


12/07/99 


04: 


27p 


12/07/99 


04: 


27p 


12/07/99 


04: 


27p 



<DIR> 
<DIR> 



File (s) 



326 Entries 
57 Repository 
46 Root 

84 6 Template 
1,275 bytes 



<DIR> 
<DIR> 



<DIR> 



29 Filets! 



11,086 BrokerManager . java 
2,088 Buyerlnfo.esidl 

19,355 BuyerManager . java 
2,416 CarAdlntf .esidl 

13,041 CarAdlmpl . j ava 
2 , 902 CarBrokerlntf . esidl 

15,108 CarBrokerlmpl . java 
2,416 CarDetails. esidl 
1,556 compile.bat 
2,929 Constants . java 
CVS 

2,137 DealDetails. esidl 

2,078 Makefile 

2,094 Payment Intf .esidl 

6,501 PaymentServer . java 

3,322 Payment Impl . java 

2,071 PTML. esidl 

2,152 Sellerlntf .esidl 

21,491 SellerManager . java 
2,190 Sellerlnfo. esidl 
8,164 Sellerlmpl. java 
2,259 SendMaillntf .esidl 
4,043 SendMail Server. java 
3,714 SendMaillmpl. java 
6,565 ServiceStopper . java 
2,367 Stoppable . java 
3,580 Util.java 

147, 625 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\usedcarsale\s 
rc\CVS 



12/06/00 
12/06/00 



04:33p 
04:33p 



<DIR> 
<DIR> 
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12/16/99 06:23p 
12/16/99 06:23p 
12/16/99 06:23p 
12/16/99 06:23p 
6 

Total Files 
4189 



File (s) 
Listed: 

File(s) 18, 



test 

1,369 Entries 
52 Repository 
4 6 Root 
84 6 Template 
2,313 bytes 



116,673 bytes 

0 bytes free 



1 

m 
Hi 
ai 
m 

ill 

m 

Q 
0 
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Chapter 1 Introduction 



This document specifies the e-speak architecture. It defines the abstractions 
presented by the system and the components that implement those abstractions, 
and shows how the components interact to create useful services. The following 
companion documents are also available: 

• E-speak Programmers Guide defines the interface for e-speak programmers 
and system developers building e-speak-enabled applications. 

• E-speak Installation Guide shows how to install e-speak and how to run some 
simple applications. 

• E-speak Contributed Services describes several sample applications included 
with the distributed software. 

• E-speak Tools Documentation shows how to use tools provided for analyzing 
the system. 



Vision 

Computing with e-speak is a paradigm switch, aiming to bring a just plug in, use the 
services you need, and pay per usage" model to computation, as opposed to the 
"install on your machine and pay per installation" model of computation prevalent 
today. E-speak is the infrastructure that realizes the vision of such a model. Instead 
of thinking of computing as some hardware you buy and the software you install on 
it, e-speak encourages you to think of computing as a set of services you access as 
needed. 
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1 



Goals 



introduction 



The reality of computing today is that it is much more complex than a utility like the 
electric or water system. An immense variety of computing resources exists, both 
in type and in power, and a newer, faster, cheaper, or better resource is probably 
invented by the time you finish reading this sentence. This dynamism is a 
formidable challenge to interoperability. 

At the same time, most of these resources are being connected to each other on a 
range of scales, from homes to companies to the entire globe. The hardware 
necessary to support such a computational utility is already available and getting 
better by the day. On the software front, though the Web has essentially achieved 
the status of a data utility, actual computation remains mainly confined to 
individual machines and operating systems. 

E-speak enables a computation utility by interposing on and mediating every 
resource access in a process called virtualization. This broad abstraction yields a 
model where machines, ranging from a supercomputer to a beeper, can be looked 
at uniformly and can cooperate to provide and use services. 



Goals 

E-speak aims at enabling ubiquitous services over the network- making existing 
resources (e.g., files, printers, Java objects, or legacy applications) available as 
services, as well as lowering the barriers to providers of new services. The 
infrastructure's goal is to provide the basic building blocks for service creation, 
including: 

• Secure access to resources and service 

• Usage monitoring, billing, and access control 

• Advertising and discovery of new services 

• Mechanisms for negotiation to find the u best" service 

• Independence of operating system, language, and device 

• Ability to support large enterprise-wide, intra-enterprise, and global 
deployments 



2 
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Architectural Philosophy 



Architectural Philosophy 

This document specifies the e-speak architecture. There are four key concepts: 

• Resource: Any computational service, such as a file or a banking service, that is 
virtualized by e-speak. 

• Client: An active entity that requests access to Resources or responds to such 
requests. 

• Protection domain: The part of the e-speak environment visible to a Client. 

• Logical machine: An active entity that performs the operations needed to 
implement e-speak. 

E-speak is based on the following: 

• All Resource access is mediated; e-speak sees all Resource requests. 

• All Resource access is virtualized; e-speak maps between virtual and actual 
references. 

• Names for Resources are shared by convention only; e-speak keeps a separate 
name space for each Client. 

This document does not specify anything outside of the e-speak architecture. 
However, some implementation details are included to show some points. These 
sections are marked "informational.'' 



Environment 

E-speak is designed to work in a hostile, networked environment such as the 
Internet. It isolates service providers and their clients from an inherently insecure 
medium while allowing them to negotiate safely, form contracts, and exchange 
confidential information and services without fear of attack. 
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Intended Audience 

This E-speak Architecture Specification describes the lower-level interfaces of e- 
speak for: 

• Implementors of Client libraries to provide a higher level of abstraction for e- 
speak 

• Implementors of utilities and tools to manage and manipulate e-speak 

• Implementors of e-speak emulation routines that are used in the run-time 
environment for legacy applications 

• Implementors of extensions to existing services and resources used by Clients 

• System administrators who implement policies for security and resource lookup 

• Those designing and building their own implementations of e-speak 



Structure 

This specification consists of the following major sections, in the order listed: 

• An overview of the e-speak architecture 

• A description of the data structures used by e-speak to describe Resources- 
Resource metadata 

• The interfaces to the e-speak platform that are exposed as "Core-managed 
Resources" 

• A description of Vocabularies, the mechanism for processing Resource 
descriptions to discover and match Resources to the Client's description of 
Resources needed 

• The e-speak mechanisms used for access control 

• The e-speak communication architecture 

• The exceptions that can be generated by the e-speak platform 
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• The e-speak Event Service 

• The e-speak management architecture 

• The e-speak Respository used for storing Resource metadata (informational) 

• A description of how localization is implemented (informational) 

• A glossary of terms 

• A brief description of probable future extensions to e-speak (informational) 

Conventions 

There are several document conventions worth noting: 

• New terms are introduced in the document flow with italics. 

• Programmatically visible architectural abstractions are written with the first 
letter of each word capitalized, such as Protection Domain. 

• Logical names, method names, and other programmatic labels are written in 
Courier font. 

• Even though e-speak is independent of the programming language, the 
specification uses Java syntax. 

• Sections describing material outside of the architecture are shown with the 
word "Informational* in the chapter or section title. 
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All system functionality and e-speak abstractions build on top of one single first- 
class entity in the e-speak architecture- a Resource. A Resource is a uniform 
description of active entities such as a service or passive entities such as hardware 
devices. Unlike most platforms, e-speak deals only with data about Resources, 
metadata, and not Resource-specific semantics. Thus, a file Resource within the e- 
speak environment is simply a description of the attributes of the file and how it can 
be accessed. The e-speak platform does not access the file directly. A Resource- 
specific handler that is attached to the e-speak platform receives messages from e- 
speak and directly accesses the Resource. 

Access to e-speak is provided by the e-speak Service Interface (ESI). Client 
applications and Resource Handlers are linked with a library that provides this 
interface. The library communicates with the e-speak platform using the Session 
Layer Security Protocol (SLS) . The e-speak platform mediates all Resource access. 
Every access to a Resource through e-speak involves two different sets of 
manipulations: 

1 The e-speak platform uses its Resource descriptions for dynamic discovery of 
the most appropriate Resource, transparent access to remote Resources, and 
sending Events to management tools. 

2 The Resource-specific handler directly accesses the Resource such as reading 
the disk blocks for a file. 

E-speak treats all Resource accesses in exactly the same manner. This mediated yet 
uniform access is the design principle that allows the e-speak environment to 
accommodate any kind of Resource type flexibly, even Resources dynamically 
defined after the e-speak system has started. 
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The e-speak platform maintains an environment for each of its Clients, called a 
Protection Domain. A Protection Domain is analogous to a "home directory" in an 
operating system. It contains bindings to Resources created by the Client and e- 
speak keeps track of memory usage due to these bindings. 

A single instance of the e-speak platform is called a Logical Machine. Figure 1 
shows a single Logical Machine. There may be multiple Logical Machines on a single 
physical machine, or the components of a Logical Machine may be distributed 
across multiple machines. Logical Machines are independent entities that 
communicate using the Session Layer Security Protocol as shown in Figure 2. 



Logical 
Machine 




Client 



Figure 1 Resource access in e-speak 



8 



Developer Release X.03.03.00, September 2000 



Architecture Overview 



ES! 




Protocol 



Figure 2 Communicating e-speak logical machines 

Each e-speak Logical Machine has a single instance of the e-speak Core. All 
Resource access is through the Core that uses the Resource metadata to mediate 
and control each access. To access a Resource, a Client sends a message to the e- 
speak Core naming the Resource. The e-speak Core uses the Resource metadata to 
locate the Resource Handler and forwards the message to the Resource Handler 
that, in turn, physically accesses the Resource. 

Although Figure 1 shows the Resource Handler being outside the Core (i.e., in a 
separate process), the handler for some Resources is the Core itself; these 
Resources are inside the Core and are called Core-managed Resources. E-speak 
Clients can manage and interact with the Core by sending messages to these 
Resources. For example, one kind of Core-managed Resource is a Resource 
Factory. When a Client wants to create a new Resource instance, it sends a message 
to the Resource Factory to register the Resource metadata with e-speak. 

Logically, there are three categories of Resource access: 
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• A service provider can choose to register the metadata of its service. The e- 
speak Resource model describes the contents of this metadata. 

• A Client or service provider may look up a service and bind to it, prior to 
accessing it. The search rules and the information model for descriptions are 
defined by the registered Resource metadata. 

• A Client or service provider may invoke an entry point on a service. The previous 
two are special cases of this last one, because they may be considered as 
invocations on entry points of Core-managed services. 

In all cases, the mediating e-speak Cores perform name resolution and generate 
monitoring information as part of this access. 

Clients who wish to access a service do so through the e-speak Core, which uses the 
appropriate Resource metadata to route the Client request to the correct handler, 
after having performed all desired name translation, and other e-speak 
functionality. 

The following sections outline the various components of the e-speak architecture 
and describe the steps in a service access. 



Mediation Architecture 

Following are the main components of the mediation architecture: 

• A set of Core-managed Resources inside the e-speak Core. The Core-managed 
services present the system functionality for managing the e-speak platform, 
including creating Protection Domains and their contents and managing 
Resource metadata. 

• A Repository containing Resource metadata available to Clients of the Logical 
Machine. These are the metadata that the Core evaluates during any service 
access. 

• A routing engine that routes all service access messages based on the contents 
of the metadata of Resources referred to in the parameters of the message. The 
implications of this are discussed below. 
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Resource Model 

The Resource is a representation of an e-service within e-speak. Service providers 
register the metadata of their services (e-speak Resources) with the Core. This 
includes the information depicted in Table 1. 



Table 1 Resource Model 



Description 


An attribute-based specification of the Resource 


Vocabulary 


The definition of the attributes and their types used in 
descriptions and lookups 


Resource Handler Mailbox 


The process/thread/task that handles the Resource 


Contract 


Denotes the Application Programming Interface (API) 
supported by the provider, including version and 
similar information 


Resource mask, owner 
public key and service ID 


Access control information 


Private Resource-specific 
data 


Data important to the provider of the Resource, such 
as the provider's internal name for the Resource. Not 
interpreted by e-speak. 


Public Resource-specific 
data 


Data important to the user of the Resource, such as a 
stub for invoking methods. Not interpreted by e- 
speak. 



The Resource metadata is maintained in the mediating Cores Repository. All 
functionality presented through the Core must have metadata within the Core. This 
is true even for the functionality provided by the Core itself. 
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Metadata System 

The e-speak metadata system is based on the following architectural and semantic 
entities: 

• Vocabularies are created as first-class Core-managed services. Thus, the model 
includes a metalanguage for creating a whole range of vocabularies with which 
to describe services, much like that of XML. XML document type definitions 
(DTDs) can be handled through the e-speak Vocabulary Builder. 

The representation of vocabularies as Resources ensures that they can be 
dynamically discovered and protected from illegal access, and that access to 
them is mediated as required, like any other service in e-speak. In the e-speak 
architecture, a created Vocabulary decides the validity of an attribute descrip- 
tion provided by a registering service provider. 

The Core-managed Vocabulary service also includes a matching engine that is 
used to match Resource descriptions available in the Repository with search 
requirements of Clients of e-speak. 

• Attribute-based service descriptions are used by service providers as part of 
service registration. These attribute descriptions are sets of name-value pairs in 
a specific vocabulary. The Vocabulary is either one that the service provider 
previously created (using the Vocabulary Builder) or discovered through the 
discovery facilities provided by the e-speak Core services. 

• Search Recipes are objects that hold a Client's recipe for discovering a 
Resource. The Core uses this to process the Resource discovery request. A 
Search Recipe specifies what Resources the Client is looking for, how the 
lookup should be done, and what should be done if multiple matches occur. The 
Search Recipe contains the predicates and a Repository view mechanism with 
which to constrain the search. A search predicate is constructed with a 
Vocabulary and a constraint string expressed in that Vocabulary. The predicate 
is expressed in a form based on the Object Management Group trader services 
constraint grammar. 

• The operational realization of the metadata system includes support for 
including arbitrary advertising services as part of extended searches, arbiters to 
optimize matches found through the Core Repositories, and integration of 
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Vocabulary translation services with the lookup/discovery process. Advertising 
services provide scalability to service lookup in e-speak by supplying a means to 
find Resources not registered in the local Repository. Arbiters are used to affect 
special purpose optimizations such as handling multiple hits in lookups. 
Translation services can be integrated with Core-managed Vocabulary services 
or created as external services, thus allowing for translation between 
Vocabularies. 



Naming Model 

The e-speak naming system is based on the following principles. 

• E-speak Names are Universal Resource Locators (URLs) . 

• Name spaces are maintained in container Core-managed Resources called 
Name Frames. Name Frames can themselves contain other Name Frames, so 
each e-speak Core has a hierarchy of Name Frames beginning from its "roof 
Name Frame. By default, when the Client specifies the name of a service, the e- 
speak Core, starting with its root Name Frame, finds mapping between the name 
and a name unique to this Core. In addition, a client can specify a name 
beginning in the root Name Frame of another e-speak Core, by specifying the 
host in the e-speak Name. 

• The e-speak Core provides the only valid reference to a service as a name in the 
Client-specific name space. This is like a virtual address of a service. The 
physical address of a service, the Core s name, is not a valid Client reference for 
a service. 

• There are two ways for a Client to get a name for a service. First, another Client, 
application, or service provider can pass it the name. Second, a Client may 
obtain a per-Client name through a bind call that requires a Search Recipe as a 
parameter. The e-speak system (Core and Client libraries) looks up the name in 
local Repositories, known remote Repositories, and if necessary a global 
advertising service to locate the appropriate service and create a binding for the 
Client in its name space. 
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• Bindings in e-speak are objects that capture an algorithm. At their simplest, 
bindings may capture a Search Recipe. These bindings may be resolved and 
frozen to a specific Core name or names, resolved and cached, or simply 
resolved on each access. This gives the e-speak system an active naming model. 
Even when resolved, a Client reference may be bound to multiple Core names, 
which may be arbitrated prior to service access. This may be done by using a 
Client-specified arbitration service that picks one particular service from a list 
of services represented in a binding. 



Access Control 

E-speak security is based on a Public Key Infrastructure (PKI). Specifically it uses 
the Simple Public Key Infrastructure (SPKI) developed within the Internet 
Engineering Task Force. 

All entities in e-speak (Resources and Cores) are identified by public keys. To 
authenticate an entity, we verify that it knows the private key corresponding to the 
given public key. No entity should ever intentionally share its private key or give 
anybody access to the private key. 

Any entity can create a key-pair. Provided the private key is kept secret, the key-pair 
is unique to that entity. However, having a key-pair gives you no power in the 
system. It is necessary also to have certificates stating access rights issued to your 
public key. 

In e-speak, access rights are stated in attribute certificates. So as well as the 
conventional use of certificates to bind a name to a public key (e.g. X.509), we also 
use certificates to bind access rights to public keys. This helps to have online access 
control databases or access control lists. 

To decide whether to honor an incoming request a Resource Handler must decide 
if it has a certificate (or certificates) granting access rights for the request. If it finds 
such a certificate, it must verify that the sender of the request knows the private key 
corresponding to the public key in the certificate to which the access rights have 
been given (formally this is the subject of the certificate). It does this by a 
cryptographic protocol that is described in Chapter 6, "Communication". 
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Communication 



Finally before honoring the request, the Resource Handler must verify that it trusts 
whoever issued the certificate. It does this by verifying that the certificate has been 
signed by an entity that it trusts. Resource Handlers do not trust all certificate 
issuer's equally. A Resource Handler can choose whether to trust a given certificate 
issuer and may restrict what access rights a given certificate issuer can issue. 



Communication 

E-speak uses a mailbox metaphor to describe the interactions between Clients and 
the Core. This metaphor does not imply that any actual messaging is required, only 
that the interfaces are defined in terms of mailboxes. Mailboxes consist of two 
forms: an Outbox and a Core-managed Resource called an Inbox. 

When a Client wants to use a Resource, it constructs a message consisting of a 
message header and a payload and inserts the message in the Client s Outbox. The 
Outbox is connected to the Core, which processes the information in the message 
header. If there is no error, the Core extracts Resource specific metadata and 
security information from its Repository and inserts this in the message before 
forwarding the message to the designated Inbox. The Resource Handler reads the 
message header and the inserted payload to determine how to deal with the request. 

The Resource specific metadata and security information inserted by the Core into 
a message can be used by the Resource Handler to determine how to process the 
message. 

As each message is routed, the e-speak Core may generate events for logging and 
monitoring. 

E-speak uses peer-to-peer communication. The Core has no concept of a reply 
message. If the Resource Handler needs to return a value to the Client, it must 
specify a Resource listing an Inbox connected to the Client in the handler field of its 
metadata. Hence, in replying to a message, the Resource Handler changes roles with 
the Client. 
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Session Layer Security Protocol 

All messages exchanged between e-speak Cores and between e-speak Cores and 
Clients use the Session Layer Security protocol. This provides secure message 
passing between entities as well as unprotected message exchanges. Applications 
can choose whether to use secure message passing or not. 

Session Layer Security protocol is designed to support e-speak mediation. E-speak 
mediation requires e-speak to modify certain parts of the message so that the 
message can be routed between endpoints and means there is no TCP connection 
between the endpoints. These requirements mean that existing protocols such as 
SSL (Secure Sockets Layer) or TLS (Transport Layer Security) are not suitable for 
end to end security in e-speak. 

Session Layer Security protocol allows multiple secure sessions to be multiplexed 
over a single TCP connection. This means that two e-speak Cores can be connected 
via a single TCP connection with many Clients and have many different secure 
sessions to different e-speak Resources. 

Session Layer Security protocol also supports tunnelling. During firewall traversal 
we might want the firewall to control the client access rights to the internal LAN for 
every packet. However, we might not want the firewall to see all the traffic in clear 
(therefore, losing the end-to-end security property). With Session Layer Security 
protocol we can nest a secure session inside another one, possibly with different 
end points, allowing us to achieve both goals simultaneously. 

Session Layer Security protocol is designed to support SPKI for access control. It 
performs the negotiation of access rights that need to be proven represented by 
multiple SPKI certificates. 

Session Layer Security supports the following encoding types for messages: 

• CLEAR_DATA: The message is not encrypted or protected against 
modification. 

• PROTECTEDJ3ATA: The message is not encrypted but it is protected 
against modification. 

• SECUREJDATA: The message is encrypted and protected against 
modification. 
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Session Layer Security has been designed to be independent of transport. However, 
for interoperability between e-speak Cores and interoperability between e-speak 
Cores and Clients, direct implementation over TCP is assumed. Other 
implementations are possible, including passing SLS messages over HTTP, or 
through shared memory. 

Core to Core Communication 

Communication between e-speak Cores uses the Session Layer Security protocol. 
Two core-managed Resources are used for remote communication between e- 
speak cores: the Connection Manager (for connection management) and Remote 
Resource Manager (for management of remote resource metadata). 

The Connection Manager sets up the initial connection, manages it and closes it 
down when it is no longer needed. It requires the host name (or IP address) and port 
of the remote e-speak Core to set up a remote connection. The Connection Manager 
has a well known name: es://<server>/CORE/ConnectionManager. So given the host 
and port number (i.e. the <serve> part) a Connection Manager can negotiate with 
the remote Connection Manager to establish a connection between the two e-speak 
Cores. Once the two Connection Managers have established a connection, Cores 
exchange Resources with each other using their Remote Resource Managers for 
Resource export and import. 

The Remote Resource Manager is responsible for managing metadata: importing 
and exporting resources from the remote e-speak core. The Remote Resource 
Manager on any given e-speak core is: es://<server>/CORE/ 
RemoteResourceManager. So given that two Connection Managers have 
established a connection between two e-speak Cores, the Remote Resource 
Managers can communicate with each other to exchange Resources. 

All resources can be exported by reference, in which case a copy of the metadata of 
the Resource is sent to the remote core. In addition certain Core-managed 
Resources can be exported by value, in which case a copy of the Resource is sent 
to the remote e-speak Core. 

Resource import and export serves a number of purposes in e-speak. 

* Resource discovery is made more efficient for local Clients, because a copy 
of the metadata is available locally. 
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The lookup mechanism requires that a vocabulary is available locally for 
both Resource registration and lookup in that vocabulary. Using Resource 
export, a vocabulary can be defined once and exported to wherever it is 
needed. 

Name Frames can be defined containing a set of useful bindings (akin to an 
environment for a Client). Using Resource export, these Name Frames can 
be made available locally wherever a Client needs them. This can be 
particularly useful for mobile clients. 



An End-to-End Example 

When the Client on Logical Machine A sends a message to its Core for a Resource 
on Logical Machine B, the following steps take place (see Figure 3): 

1 The Client constructs and Session Layer Security message setting the 41 to* 
address to the Name of the Remote Resource (e.g. es://<host_for_core_B>/ 
resource/foo). The from address is set to the Name of the Client (e.g. es : // 
<host_f or_core_A>/ client/bar). This message is sent using TCP to Core 
A, where it is placed in the Client s outbox. 

2 A message handling thread in Core A, picks up the message and sends it to Core 
As router. Core A's router determines that the message is for Core B. It checks 
that it has a connection with Core B and forwards the message to the relevant 
inbox. 

3 A message handling thread on Core A picks the message up from the inbox and 
transmits it to Core B (via a TCP connection) where it is placed in the outbox for 
incoming messages from Core A. 

4 The router on Core B resolves the Name for the " to address" in its root Name 
Frame. The resolved name is a binding to the Resource metadata. 

5 Core B s router retrieves the Resource's metadata. This tells it to which inbox to 
send the message. It also extracts the Private Resource Specific data and various 
security information that is used by the Resource Handler to process the 
message. 
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The E-speak Service Interface (Informational) 



6 A message handling thread picks the message up from the inbox and sends it to 
the Resource Handler through a TCP connection. 

7 Any communication between the Resource Handler and the physical Resource 
is outside of the control of the e-speak Core. 



Logical Machine A 



Resource 
Hindlcr 




Resource 










Logicai Machine B 



OB - Outbox 
IB = Inbox 



Figure 3 Distributed e-speak 



The processing for any return message is similar, except the roles of the respective 
e-speak Cores are reversed (recall e-speak is asynchronous - the Core does not 
distinguish between request and reply messages when routing them). 



The E-speak Service Interface (Informational) 

An e-speak Client is an application running in its own address space that was 
written using an e-speak Service Interface (ESI). There is one ESI for each 
programming language supported. An example ESI is shown in Chapter 1 of the E- 
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speak Programmer's Guide. This provides a rich environment offering rapid, 
secure-service development, deployment, and management in a heterogeneous 
networked environment. 



E-speak Services 

E-speak has the following services: Event, management and advertising. 

• The Event Service allows applications to collaborate by publishing Events and 
subscribing to Event distributors. The e-speak Core uses the Event Service to 
publish Events to the management service. 

• The Management Services manage interconnecting sets of e-speak Cores, 
managing the distribution of metadata, and e-services registered as e-speak 
Resources. 

• The Advertising Service is used for distributed Resource discovery in large-scale 
environments. 



Standards 

The e-speak platform builds upon and uses existing industry standards wherever 
possible. In some cases, integration with industry standards is under way or 
planned. The specific areas of integration include: 

• Database access- The persistent back-end for the Repository uses Java 
Database Connectivity, thus making it possible to send Repository queries to 
almost any relational database. 

• Advertising services- The Advertising Service back-end is provided by 
Lightweight Directory Access Protocol 

• Transport protocols: The ESIP messaging stack supports pluggable transports. 
TCP/IP, IrDA, WAP, and HTTP are all candidate transports. 
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* Service description: E-speak supports multiple different Vocabularies, including 
forthcoming support for XML and X.500 schemas. 

♦ Component models: These models integrate the e-speak service abstraction 
with standard component models such as (Enterprise) Java Beans, CORBA, and 
COM+. 

• Management protocols and standards: Support for SNMP, ARM, and DEN is 
planned. 

• Languages: An E-speak library exists for Java, but e-speak has been designed to 
be language independent. Any language can be used to construct an Session 
Layer Security message which is all that is required to use e-speak. 



Summary 

E-speak presents a uniform service abstraction, mediated access, and manipulation 
of Resource metadata. This creates an open service model, allowing all kinds of 
digital functionality to be reasoned about through a common set of APIs. New 
service types and semantics can be dynamically modeled using the common service 
representation of an e-speak Resource. 

The naming system provides active bindings and personal name spaces. The 
connection between Clients and Resources can be reasoned about and formed at 
run-time (upon each access if necessary) based on arbitrary search characteristics. 
Personalization of views and environments and hot-plug replacement of Resources 
all become possible. 

The access control is based on a Public Key Infrastructure using attribute 
certificates for scalable distributed security. This is supported by the Session Layer 
Security protocol which allows messages to be protected against tampering, 
eavesdropping or replay. In addition the Session Layer Security protocol allows 
unprotected messages to be sent, should security not be needed. Session Layer also 
supports authenticated tunneling for efficient and secure firewall traversal 



Developer Release X. 03.03.00, September 2000 



21 



Summary 



Architecture Overview 



The metadata system defines Vocabulary models as first-class entities in the system 
that can be reasoned about in the same manner as all other services. Translation 
and lookup through scalable advertising services are integrated into the model. 
Service location and discovery can thus seamlessly deal with a situation where the 
Client describes its requirement in an X.500 schema, while the service provider 
describes its service using an XML DTD. 

The distribution model supports a flexible set of access methods. Thus, 
downloading printer drivers and the remote access of a file are equally well 
supported by the model. The separation of the infrastructure into interacting 
Logical Machines builds on the autonomous machine model provided by the Web. 

These are the defining features of an open services platform. The collection of the 
capabilities discussed above creates an environment where services on the Internet 
can interact in a secure, dynamic, manageable way. The next chapter of the Internet 
(e-services) is being written, and e-speak helps us understand it. 
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Outline 

E-speak Resources include all the entities called " Services" in the ESI, together with 
programs and data entities held in the Core to enable the use and management of 
Services. The Services are called "External Resources" in the Core software, and 
the aids to using them are called " Core-Managed Resources" . The programs and 
data of an external Resource are not seen by the core, and are managed by an 
external Resource Handler. What is held in the core for any Resource is its 
metadata, consisting of: 

• Resource Description, allowing Clients to find the Resource. 

• Resource Specification, enabling use of the Resource. 

The types of Resource and a breakdown of the metadata that each Resource has are 
tabulated below. The terms will all be explained in this Chapter. 

(One complication has been left out of the diagram and will not be discussed in this 
Chapter: the metadata for any Resource is itself an instance of a core-managed 
Resource class called MetaResource. MetaResource is discussed in Chapter 4, 
"Core-Managed Resources" under "* Resource manipulation" on page 71" - the name 
of the interface used to act on Metadata.) 

In the table below, Vocabularies and Contracts are separated from all the other 
Core-Managed Resources because they are both types of Resource and items of 
metadata. Advertising is distinguished from other (external) Resources because an 
ESI is likely to handle advertising differently from the creation of Services, as J-ESI 
does. The e-speak Core makes no distinction between advertising and other 
external Resources. 
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Figure 4 - Resource Types and Metadata 



RESOURCE TYPES 



METADATA 
ITEMS 



Vocabs. Contracts Other Core-Managed External Services 

Resources (Direct) (Advertising) 



DESCRIPTION 



Vocab. Attribs. 
Vocab. Attribs. 



All metadata items apply to each of the Resource 

types 



Vocab. Attribs. 



SPECIFICATION 
Contract: 

Vocabs. 
Interface. 

Inbox 

Security Masks 
Filter 

Owner public key 
Owner ESName 
Handler ESName 
Resource Specific 

Data 
Serviceld 
ESuid 
URL 

byVake (boolean) 
eventControl 



A Client registers a Resource by sending a message to the Core-Managed Resource, 
ResourceFactory, containing the metadata. If the registration succeeds, the Core 
returns a name bound to this Resource to the Inbox specified by the client. The 
metadata will be held under the same name in the Repository. The metadata 
comprises the whole of the information the Core uses to handle requests for the 
service and searches for it. 



24 



Developer Release X.03.03.00, September 2000 



Resource Data, Searches & Vocabularies 



Resource Descriptions 



Resource Descriptions 



The simplest Resource Description consists of a set of names and corresponding 
values, together with an ESName referring to a Vocabulary which specifies the kind 
of data under each name. For example, a translation Resource could have the 
description: 



es://17.56L12337:12356/vocabs/trans!a- (Vocabulary reference) 
tion 



name (String) 

SourceLanguage 
TargetLanguage 

InputFormat 

OutputFormats 

Price 



vaiue (Value) 

0x00 Japanese 

OxOE English, Korean, 
Russian, Mandarin 

0x00 Unicode 

OxOE ASCII, Unicode 

0x08 20000 



essential 
(boolean) 

true 

false 

false 
false 
false 



This description is an instance of AttributeSet. The rows consisting of a name, 
a Value and the boolean essential are instances of Attribute . A 
ResourceDescription consists of one or more AttributeSet instances. 
Different parts of the description may have different Vocabularies, and if so must be 
expressed in different AttributeSet s. 

Vocabularies are explained at the end of this Chapter. Although each instance of 
Value has a value-type code (seen above) , a Vocabulary is needed to define its 
significance. The "price* could be in Yen per kilobyte of input, for example. 
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The boolean essential, if true, means that the Resource will not be returned in 
response to a SearchRecipe that omits this Attribute name and value. This can be 
used to set passwords for the discovery of a Resource. (The use of the Resource is 
controlled by the security mechanisms in (Chapter 5, "Access Control"), 

Value class 

Instances of Value have a 1-byte tcode and an Object val . The tcode 
indicates the type of val. It is one of these static final codes defined in the class: 

STRING_TYPE_CODE = 0x00; 
L0NG_TYPE_C0DE = 0x01; 
DOUBLE_TYPE_CODE = 0x02; 
BOOLEAN JTYPE_CODE = 0x03; 
BIGJ3ECIMAL_TYPE_CODE = 0x04; 
TIMESTAMPJTYPE_CODE = 0x05; 
DATE_TYPE_CODE = 0x06; 
TIME_TYPE_CODE = 0x07; 
INTEGER_TYPE_CODE « 0x08; 
FLOAT_TYPE_CODE = 0x09; 
CHARJTYPE_C0DE = 0x0 A ; 
BYTE_ARRAY_TYPE_CODE = OxOB; 
BYTEJTYPE_CODE « OxOC; 
SHORT_TYPE_CODE = OxOD; 
SET_TYPE_CODE = OxOE; 
NAMED0BJECTJTYPE_C0DE = OxOF; 
OTHER__TYPE_CODE = OxFF; 
INVALID_BASE_TYPE_CODE = OxFF; 

In all but the following cases, a Value is marshalled in e-speak serialization format 
The exceptions are: 

• tCode = SET_TYPE_CODE: val contains a set of values. This is not 
supported in the current release. 

• tCode - BIG_DECIMAL, DATE, TIME, TIMESTAMP, NAMEDOBJECT: val 
is sent as a String. The first 4 types are taken from the Java packages: 

• j ava . math . BigDecimal , 

• java.sql .Date, 

• j ava . sql . Time , 

• j ava . sql . Timestamp . 
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Resource Specifications 

The ResourceSpecif ication class is defined below, 
public class ResourceSpecif ication 

{ 

boolean byValue; 
ESName contract / 
FilterSpec filter; 
ADR metadataMask; 
ADR resourceMask; 
ADR ownerPublicKey ; 
ADR Serviceld; 

ESMap privateRSD; //Not exported if export by reference 
ESMap publicRSD; 

ESName owner; //Not exported 

ESName resourceHandler ; //Not exported 

int eventControl ; 

ESUID uid; 

String URL; 

} 

boolean byValue 

This flag governs the export of the Resource to another Logical Machine. See 
(Chapter 6, "Communication"). If byValue is True, a copy of the Resource itself 
will be included with the Resource Specification and Resource Description 
exported. The copy of the Resource can then be used on the receiving platform. The 
Core will provide this copy for Core-managed Resources. Currently, there is no 
mechanism for providing copies of external Resources. They can only be exported 
"by Reference" , and only used remotely. 

ESName contract 

The contract field is the name of the Contract Resource associated with the 
Resource. An e-speak Contract is not an agreement between parties, but a provision 
to make a [Resource usable. It can contain: 

• an interface which the Resource will implement. 
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• one or more Vocabularies which can be used to frame queries in a search 
for Resources implementing that interface. 1 

A search may be required because several Resources may implement the same 
interface. 

A Resource cannot be registered without a valid contract field, so the Contract 
itself must have already been registered. The Contract given in the Specification of 
a Contract is ContractContract - what else? It is supplied by the Core. 

Contract implementation (informational) 

The current J-ESI creates ESContracts, containing an interface which has been 
generated by an Interface Definition Language (IDL) compiler, ES-IDL. The 
ESContract also contains Terms of Use, a Conversations scheme and the ESName 
of the interface. An ESContract creates a core Contract. All the interface 
information is put in the privateRSD field of this core Contract's metadata, in a 
format interpreted by J-ESLThe following diagram illustrates this. 



Resource Metadata Descnpcion 

Specification Contract Contract Metadata Description 

Filter Specification Contract (■ ContractContract) 

FUter 

Pubhc RSD 

Private RSD Pubhc RSD 
PnvateRSD 



A core Contract is constructed with an array of Vocabulary identifiers 2 and a 
ResourceType. The latter is one of several integer constants defined in the 
ResourceType class, and listed below. Contracts for all external Resources have a 
ResourceType of EXTERNAL_CODE, = 1000. Each Core-Managed Resource has an 
appropriately named ResourceType. 

Current ResourceTypes: 

fit-.aHc inf TNBOX COOK = 0: 

1 This feature may be discontinued 

2 Vocabularies may be omitted from contracts in future releases 
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Static int META_RESOURCE_CODE = 1; 

static int PROTECTION J)OMAIN_CODE = 2; 

static int RESOURCE_FACTORY_CODE = 3; 

static int CONTRACT_CODE = 100; 

Static int CORE_DISTRIBUTOR_CODE = 110; 

Static int IMPORTER_EXPORTER_CODE = 120; 

static int MAPPING_OBJECT_CODE = 14 0; 

static int NAME__FRAME_CODE = 150; 

static int REPOSITORY_VIEW__CODE = 160; 

static int SECUREJBOOT_CODE * 170; 

static int SYSTEM_MONITOR_CODE = 18 0; 

Static int VOCABULARY_CODE = 190; 

static int CORE_MANAGEMENT_SERVICE_CODE = 200; 

static int DEFAULT__VOCABULARY__CODE = 210; 

static int DEFAULT__CONTRACT_CODE = 220; 

static int F INDER_S ERVI CE_CODE = 230; 

static int CONNECT I ON_MANAGER__CODE = 240; 

Static int REMOTE_RESOURCE_MANAGER_CODE = 250; 

static int EXTERNAL^ CODE « 1000; 

static int EXTERNALJRESOURCE CONTRACT CODE = 1001; 
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Contract Methods 

Contract methods include: 

• void register (ResourceDescription, ResourceSpeciflcation, boolean 
persistence) 

• RepositoryHandle[] getVocabulariesO 

• void addVocabulary (RepositoryHandle vocab) 3 

• String getResourceType 0 

• AbstractResource createResource (ResourceDescription, 
ResourceSpeciflcation, boolean persistence, Object arg) 

• void SendObject(MessageOutputStream) used to export a Contract 

• Object ReceiveObject(MessageInputStream) used to import a contract 

This is only a sample. A RepositoryHandle is a unique identifier of an item in a 
Repository (see Chapter 4, "Core-Managed Resources"). The last three methods 
provide a standard signature for creation, export and import of every kind of 
Resource. 

FilterSpec filter 

class FilterSpec { 
ESSet Vocabularies; 
String constraint; 

} 

The filter is a way to restrict discovery of the Resource to particular Clients or 
classes of client. The constraint String is made up of conditions which the 
Client making a search must satisfy. All the names of Attributes must be in one of 
the Vocabularies, and all the values must be of the type and within the range 
specified in that Vocabulary. 



3 May be omitted in future releases 
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Filter implementation (informational) 

The constraint String has to specify a source for each Attribute value, and the 
Vocabulary for it if there is more than one - because the Vocabularies might include 
different Attributes with the same name. 

The source of Client details is commonly the Client s UserProfile - part of the 
AccountManager Resource (see Chapter 4, "Core-Managed Resources"). When this 
is so, the Attribute name in the constraint is prefixed $user/. Otherwise, the 
Attribute can only be taken from the Resource Description. For example, if a 
ResourceDescription and a UserProfile both include the Attribute "State", the 
constraint might include " $user/State = State" . 

If there are multiple Vocabularies, Attributes are preceded by the Vocabulary name 
and a colon. For instance, where Vocabularies called "home" and "workplace" are 
in the FilterSpec, the constraint could include *$user/home:State = 
workplace:State\ The second "State" here must be in the ResourceDescription. 

ADR metadataMask 

The metadataMask controls which operations manipulating the Resource s 
metadata will have security disabled - so no certificates or Message Authentication 
Code are required to invoke them. The interface name in the metadataMask will 
always be the ResourceManipulationlnterface. The format of the metadata Masks is 
specified in Chapter 5, "Access Control* 1 - Section ""Disabling Security" on 
page 102". 

ADR stands for Ascii Data Representation. It is an abstract class: one extension of 
it is ADRAtom, and other extensions implement the interface Tag. These are the real 
classes which a metadataMask can instantiate. The Tag or ADRAtom identifies 
the operations that are free of security restrictions. Tags are described in (Chapter 
5, "Access Control"). 

ADR resourceMask 

The resourceMask determines which operations supported by the Resource will 
have security disabled. The format of the Resource Masks is specified in Chapter 5, 
" Access Control" - Section ** Disabling Security" on page 102". 
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ADR ownerPublicKey 

This field contains the owner's public key or a hash of it. The format is specified in 
Chapter 5," Access Control" - Section SPKI BNF Formats" on page 109). The ADR 
extensions that can be used for ownerPublicKey are PublicKey and Hash. 



ADR Serviceld 

This field contains the serviceld of the Resource. Servicelds are defined in Chapter 
5, "Access Control" - Section MM Service Identity" on page 88". This field can be any 
extension of ADR; it usually implements Tag. 



ESMap publicRSD 

*RSD" stands for Resource Specific Data. PublicRSD is used by the Client 
registering the Resource to insert any information he wants potential users to know. 

ESMap is an e-speak implementation of Hashtable. It consists of a series of Objects, 
each even-numbered Object being used as a key, and the following Object being the 
associated value. Both the key and value Objects are byte-arrays in the two RSD 
classes. ESMap is serialized as ESArray (see Chapter 6 t "Communication" for the 
e-speak serialization format for ESArray) . The e-speak convention for ESArray is 
that it consists of a sequence of pairs - preserving the key- value pairs of the ESMap. 

In the two RSD classes, no duplicate keys, null keys or null values are allowed. Any 
of these raises an exception. 



ESMap privateRSD 

This field is used by the Resource Handler when a Client sends a message to the 
Resource. Access to the privateRSD is commonly confined to the Resource 
Handler, but permission can be granted to any task using the e-speak security 
mechanisms. The use of this field in a Contract for the interface implemented by the 
Resource has been noted. Otherwise the field is most often used to carry the 
Resource Handler's designation for the Resource. 
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ESName owner 

The owner field is the ESName of the active Protection Domain of the Client that 
registered the Resource. A Protection Domain is a Core-Managed Resource 
corresponding to a users home directory in Unix, or to a "folder" in J-ESI. (See [ E- 
speak Programmer's Guide] and Chapter 4, 44 Core-Managed Resources".) This field 
can be changed to another Protection Domain by any Client that has authorization. 
It is an error if the ESName is not bound to any Protection Domain. 

The owner and resourceHandler fields are not included when the 
ResourceSpecification is serialized for export (see Chapter 6, "Communication"). 
The privateRSD field is only included in an export serialization if the export is by 
value. 



ESName ResourceHandler 

This is the ESName of the inbox, to which messages sent to this Resource will be 
delivered. This field is alwaysNULL for Core-managed Resources, and only for 
these. The Client that has connected to this Inbox will receive messages for this 
Resource. (The format of these messages is defined in Chapter 6, 44 Communication" 
- Section u Protocol Data Unit (PDUT ) . It is an error if the ResourceHandler ESName 
specified by the Client is not bound to an Inbox. 



int eventControl 

If eventControl is non-zero, then whenever the Resource metadata (the 
Resource Description or the Resource Specification) is changed, an Event will be 
published to the Core s Event distributor. 

ESUID 

public class ESUID 

{ 

byte [] Uniqueld; 

} 
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An ESUID contains a byte array that is up to 64 bytes long. The ESUID of a Resource 
is guaranteed unique to a very high probability. As the URL and the Serviceld also 
identify the Resource, it is not certain that this field will be retained. Currently it is 
used in some Core programs. 



String URL 

This field is the ESName (represented as a String) by which the registering entity 
refers to the Resource. It is an ESName (URL) which others can use to access the 
Resource. 



Searches 

Search Context (Informational) 

A search is initiated by a Client. In the current J-ESI, the Client can create a Finder 
of one of three classes - ESVocabularyFinder, ESContractFinder or 
ESServiceFinder. Each has a find (ESQuery) method, where theESQuery 
expresses the attributes the Client needs. Clients providing a Service are likely to 
use the ESVocabularyFinder, to obtain a suitable standard Vocabulary to describe 
the Service. This can make it more widely visible. Either providers or users may 
search for a standard Contract. A user may then: 

• Construct an ESServiceFinder, stating the Contract or its interface. 

• Use Vocabularies obtained from the Contract 4 or an ESVocabularyFinder to 
frame an ESQuery argument 

• Call ESServiceFinder.find with that ESQuery to discover the Service he wants - 
in one or more stages. 



4 Contracts may not continue to hold vocabularies 
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If the J-ESI find is successful, a stub for the Resource is returned to the client. He 
can then call the Resource as if it were on the same platform. The stub will generate, 
serialize and send the PDU messages through the core needed to invoke the 
Vocabulary, Contract or Service methods (see Chapter 6, "Communication"). 

All three J-ESI Finders use the same core Finder Resource class, and there is no 
distinction in the core software between finding a Vocabulary, Contract or external 
Resource. The ESQuery is represented by a SearchRecipe, described below. The 
information content of the SearchRecipe will be the same as that of the ESQuery. 

Finder Resource 

This is a Core-Managed Resource to carry out a Client's find 0 command. It provides 
for searching in several stages, if many Resources satisfy the query. 

Initial Search 

An initial search is carried out by this method: 
interface Finderlnterf ace { 

FinderResults find (SearchRecipe recipe, int maxToFind) 
throws ESInvocationException, LookupFailedException; 

The argument maxToFind is the maximum number of results to return. If it is set 
to 0 then the request is only to know if there are any search results - not what they 
are. If it is set to -1 the method returns all results found. There is a field in 
SearchRecipe which serves the same general purpose, so maxToFind may be 
discontinued. We refer below to "the limit* however it is set. 

The returned FinderResults has these fields and public get —0 methods to 
retrieve each of them: 

class FinderResults { 
private ESname[] esnames; 
private int [] servicelds; 
private FinderContext context; 

The first two fields contain ESNames and servicelds of Resources matching the 
SearchRecipe. The size of each array will be either the number of Resources which 
match, or the limit - whichever is least. A FinderResults method, boolean 
hasMoreResults ( ) returns true if there are more Resources than the limit 
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Follow-on searches 

If hasMoreResults () is true, then another batch, again up to the limit, can be 
obtained from a follow-on search, using the opaque FinderContext byte array 
context from the previous FinderResults . (The getContext ( ) method 
obtains context , but is not available for Clients to use directly,) The follow-on 
method is: 

FinderResults find (FinderContext context) 

throws ESInvocationException, LookupFailedException; 

} 

class FinderContext { 
byte [] queryContext 

Finder details: 

• The LookupFailedException is raised when there was an error in the Core during 
the search. 

• When the limit is 0, (meaning one only wants to know if any Resources match 
the SearchRecipe) the initial search will return a non-null FinderResults 
object if there are some. Call this u outcome" . The code: 

ESNamesH outray = outcome . get ESNames {) ; 

will yield an array of length 1, but outray [0] will be null. If there are no results, 
outcome is null. 

SearchRecipe 

A SearchRecipe is the expression of attributes a Resource must have to satisfy a 
Client s needs. Instances of the class are constructed with the following arguments: 

• ESSet vocabularies - a set of ESNames of the vocabularies holding the 
attributes used in the constraint and preferences. The registered names 
of these vocabularies are prefixed to the attribute-names in the constraint 
and preferences if more than one vocabulary is used -otherwise there could 
be confusion between homonymous attributes. 
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• String constraint - consisting of attribute- values, relational operators and 
logical operators, which must be satisfied by the corresponding attributes in a 
ResourceDescription, for the Resource to qualify. For instance: "price LE 20000 
AND maker 's__name EQ Hewlett-Packard" could in principle be part of a 
constraint . (The current syntax used is different - see below.) 

• An optional ESArray preferences - an array of Preference objects, described 
below, which can be used to rank Resources in an order of preference, if more 
than one Resource satifies constraint, 

• An optional int arbitation - limiting the number of resources to return. 

• An optional ESName repos it oryview - a set of RepositoryHandles delimiting 
the ResourceDescriptions which will be checked against the 
constraint . (See Chapter 4, * Core-Managed Resources"). 

SearchRecipe Context (Informational) 

Clients specify SearchRecipes only indirectly, using an e-speak API. The Core 
architecture only specifies the data types of the SearchRecipe fields, not their 
internal syntax or meaning. However, implemented may need to know about the 
latter, which is that of the corresponding fields in a Client s ESQuery. 

Constraint field 

The syntax of the constraint field conforms to the OMG Trader Services Constraint 
Language, except for the means of testing multi-valued attributes. See [ESRL Spec 
V4.1] and [CORBA services Document 12]. 

Preferences field 

The elements of the ESArray preferences are instances of the Preference class: 

Class Preference 
{ 

final static int MIN= 1; 
final static int MAX= 2; 

final static in WITH^ 3; 

private int type,* 

private String expression; 

private String weight; 

} 
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The type must be MIN, MAX, or WITH. The expression must be subject to comparison 
operators if the element has type MIN or MAX. It must have a boolean value if type is WITH. 
A weight needs to be specified only for Preference elements of type WITH: it must then 
have a numeric value. The order of the MIN and MAX elements in the preferences array 
is important. 

Examples (omitting vocabulary qualifiers, and not using a formal syntax) : 
MAX * Year_of_manufacture* 
MIN "Price* Mileage" 
WITH" Color == Blue* "5" 
WITH "Color != Green "T 

How Preferences work 

Assume these Preferences, in the order given, are used to order a set of car 
"Resources" which have already passed the constraint. 

• The WITH elements take precedence. Each car is given a score: the sum of the 
weights in the WITH tests that it passes. Any blue car will have a weight of 7 
(because it is blue and not-green). All blue cars will lead the list of preferences, 
followed by all other cars that are not green, with green cars at the bottom of the 
list. 

• In each set based on the WITH tests, the MAX and MIN comparisons are applied, 
in the order they are listed . The year 2000 cars will be at the top of each set based 
on the WITH weights. 

• Each year-group will finally be ordered by the MIN Price * Mileage test - those 
with the lowest Price.Mileage product coming first in their group. 

Arbitration field 

Any positive value N in this field means * Return up to N Resources". Suppose M 
Resources passed the constraint, then the number C = min(N, M) will be returned. 
If there are preferences, the first C in the preference list will be returned. Otherwise 
C Resources are returned, but the choice is undefined. 

The field may be negative, with values defined in: 



38 



Developer Release X. 03.03.00, September 2000 



Resource Data, Searches & Vocabularies 



Vocabularies 



class ArbitrationPolicy 

public static final int ALL= -1; 
// To return all resources passing the constraint 

public static final int ANY= -2; 
// To return 1 resource - the most preferred if there are 
preferences 

public static final int NEGOTIATE = -3; 
// Reserved to invoke an arbitrator resource - not currently used 



Vocabularies 

An e-speak Vocabulary is a description of terms used in a Resource Description, in 
parts of a Resource Specification or in a Search Recipe. 

Formally, a Vocabulary is an At tributePropertySet, as described below, with 
a description String. It is itself a (Core-Managed) Resource, with a 
ResourceDescription and Specification, and it can be searched for. The 

ResourceDescription of a Vocabulary must itself have a Vocabulary To end the 

recursion, the e-speak Core will ship with a Base Vocabulary preloaded. The Base 
Vocabulary will always be in the Core and accessible to all clients. Descriptions that 
don't use any other Vocabulary use the Base Vocabulary. The Core also supplies a 
Vocabulary Contract, for the ResourceSpecification of a Vocabulary. 

The following diagram summarizes the use and make-up of Vocabularies. 
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Figure 5 Vocabularies and their Uses 
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Notes on Preceding Figure: 

• Items followed by a ?\ such as "essential 7 are boolean. 
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* ine uasneu line rrom i L,oue 10 vaiue type indicates a one-io-one 

correspondence. For example, if an Attribute Trice" in an AttributeSet has the 
tCode INTEGER JTYPE.CODE (0x08) , the Vocabulary of that AttributeSet must 
have the ValueType "Integer" in the entry for Trice*. 
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Vocabulary Context (informational) 

Vocabularies are essential both to describe and specify Resources, and to discover 
them. Any Client can make up and register his own Vocabularies, but if most of 
them did so, we'd have a tower of Babel, or worse. It is expected that 
standardization bodies or Service associations will develop all the significant 
Vocabularies, advertise them and control them using Access Control (Chapter 5, 
"Access Control"), 

Vocabulary class and methods 

The Vocabulary class is outlined below: 
class Vocabulary 

{ 

private String description; 
private AttributePropertySet props; 

String getDescription { ) 
throws ESInvocationException; 

AttributePropertySet getProperties () 
throws ESInvocationException; 

boolean mutateProperties (AttributePropertySet props) 
throws ESInvocationException QuotaExhaustedException, 
StaleEntryAccessException; 

// Exchanges current AttributePropertySet for props - returns 

true if any difference 

boolean isLegalSet (AttributeSet ast) 

// Checks if ast is legal under this Vocabulary, using 
AttributePropertySet . isLegalSet { } 
public Vocabulary release () 
public void finalized 

// Both of these take the Vocabulary out of use 

The standard createResourceO, sendObjectO and receiveObjectQ methods are not 
listed. 
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AttributePropertySet (APS) Methods 

The following methods of AttributePropertySet are used in building a Vocabulary or 
registering a Resource 

• Object addAttributeProperty (AttributeProperty ap) - this is the 
way an APS is built up. 

• boolean isLegalSet (AttributeSet attrs) - this is called by 
Vocabulary. isLegalSet ( ) to test whether attrs is valid for this APS. The 
tests made are: 

• Are all mandatory attributes included in attrs? 

• Is every attribute in attrs in this APS? 

• Do all the tCodes of the Values in attrs agree with the corresponding 
ValueType in the APS? 

• Where there is a range defined in the APS, is the Value of the corresponding 
Attribute in attrs within that range? 

• AttributePropertySet getMandatoryAt tributes () -used by the 
preceding method, and maybe by others. 

Attribute Properties 

An APS is an ESMap: it consists of a paired name and AttributeProperty 
instance for each Attribute in the Vocabulary. The name is duplicated within the 
AttributeProperty . The following table shows the fields of 
AttributeProperty. 
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Table 2 Components of an attribute property 



Type 


Field 


Meaning 


String 


attrName 


Attribute name 


String 


description 


Human-readable description 


ValueType 


attrValueType 


See Table 3 for encoding 


Value 


defaultVaiue 


Default value 


String 


definition 


Expression to evaluate for a 
dynamic attribute 


boolean 


multivalued 


True if multiple values 


boolean 


mandatory 


The attribute must be specified if 
mandatory is True 


int 


rangeKind 


0 NO.RANGE 1 LEFT_RANGE 
2 RIGHT_RANGE 3 FULL_RANGE 


int 


keylndexType 


Use for repository lookup: see 
below 


double 


minRange 


Smallest allowed value 


double 


maxRange 


Largest allowed value 



• de f aul t Value : If the attribute is absent from an AttributeSet A, and is not 
mandatory, the XXXXXX will insert it in A with defaultVaiue. 

♦ definition : Dynamic attributes are not supported in the current release. 
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♦ multivalued: If this is true, an ESSet of values is expected, and the 
defaultValue should be such a set. (See the e-speak serialization format in 
Chapter 6, Xommunication , for the definition of ESSet). 

• mandatory: If true, all AttributeSets under this Vocabulary must include the 
Attribute named. You won't be able to register a Resource whose description 
uses the Vocabulary, if the AttributeSet lacks this Attribute. 

• rangeKind : specifies what kind of range-checking will be done on the 
Attribute s value, in relation to minRange and/or maxRange. The capitalized 
alternatives are integer constants defined (static final) for the class: 

• NO_RANGE - There is no restriction, whatever minRange and maxRange 
may be. 

• LEFTJRANGE - Values must be >= minRange 

• RIGHT_RANGE - Value must be <- maxRange 

• FULL.RANGE - Both LEFT_RANGE and RIGHT_RANGE rules apply. 

* keylndexType : To support lookup in a repository based on a Database 
Management System (DBMS). Valid values of keylndexType are: NOJNDEX 
(0), HASHJNDEX (1) and TREEJNDEX (2). If the value is HASHJNDEX or 
TREE JNDEX the attribute will be used for index look-up by the DBMS. This is 
discussed further in Chapter 10, "Repository (Informational)". 

Class ValueType 

Instances of this class have the private fields: 

string typeName ; // Must be one of the designators in Table 3 

String description; // Human-readable description 

String matcher; // An applicable relation, such as "islessThan" 

int baseTypeCode ; / / Equal to tCode in Values, except for invalid Type 

typeName must be one of the Designators in the following table. These are defined 
(as static final String) in the ValueType class. Each corresponds to one of the 
allowable t Codes in class Value. The Matching rules and Operations are used to 
check the validity of expressions in a SearchRecipe or filter. 
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Table 3 Supported value types 



Data type 


Designator 


Matching rules 


Operations 


Big decimal 


"BigDecimal" 


eq, ne, It, le, gt, ge 


+, % *, / 


Boolean 


" Boolean" 


eq, ne 


AND, OR 


Byte 


"Byte" 


eq, ne 




Byte array 


"Byte Array" 


eq, ne 




Char 


"Char" 


eq, ne 


+ (concatenate, 
returns oinng; 


Date 


" Date" 


eq, ne, It, le, gt, ge 




Double 


" Double" 1 


eq, ne, It, le, gt ge 


+, -. *,/ 


Float 


"Float" 


eq, ne, It, le, gt ge 


+. *./ 


Int 


"Integer" 


eq, ne, It, le, gt ge 


+, -. *. / 


Long 


"Long" 


eq f ne, It, le, gt, ge 


+,-. *./ 


Object 


"NamedObject" 






Short 


" Short" 


eq, ne, It le, gt ge 


+, *. / 


String 


"String" 


eq, ne 


+ (concatenate) 


Time 


"Time" 


eq, ne, It, ie, gt, ge 




Time stamp 


"Timestamp" 


eq, ne, It, le, gt, ge 
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Base Vocabulary 

The Base Vocabulary available at system start-up includes the attributes and value 
types shown in Table 4. 

Table 4 Base Vocabulary definition 



Attribute name 


Value type 


Comments 


Name 


String 




Type 


String 




ResourceSubtype 


String 




ESGroup 


String 




ESCategory 


String 




Description 


String 




Keywords 


String 


Multivalued 


Version 


String 




ESDate 


Date 


" YYYY-MM-DD" 


ESTime 


Time 


"HH:MM:SS" 


ESTimeStamp 


TimeStamp 


"YYYY-MM-DD 
HH:MM:SS.FFFFFFFFF" 


HashAigorithm 


String 




HashCode 


BigDecimal 


To authenticate contents 



The hash algorithm is specified using well-known names, for example, MD5. 
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Base Account Vocabulary 

The Base Account Vocabulary is also available at startup. It is used for discovering 
user accounts. 

Table 5 Base Account Vocabulary 



Attribute name 


Value type 


UserName 


String 


Userlnfo 


String 


UserType 


String 


User Location 


String 


UserESURL 


String 



The above attributes match the fields defined in Authlnfo and UserProfile. For more 
information, see" The Account Manager Resource" section in Chapter 4, * Core- 
Managed Resources." 

The description string for the Base Account Vocabulary is: "E-speak base user 
vocabulary". 

Translators (Informational) 

The interoperation of different Vocabularies may be supported through Vocabulary 
Translators. The translator would map attributes from one Vocabulary into 
another, but there is no direct linkage between a Translator Resource and any 
Vocabulary Resource, A translator service is not part of the e-speak architecture; it 
would be an external Resource. 

The translator envisaged would implement: 

ESName [] [2] getVocabularyPairs { ) ; 
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which queries the translator about Vocabularies known to it. The translator returns 
an array listing all Vocabularies that it can translate in an ordered set. Each element 
in this array is a pair of Vocabulary names. 

boolean isCompatible {Vocabulary vocabularyl, 
Vocabulary vocabulary2) 

checks if the translator can translate from the first given Vocabulary into the second 
given Vocabulary. If the translator can perform the translation operation on the 
given pair of Vocabularies, it will return true. If the translator cannot perform the 
translation, or if it does not understand either of the Vocabularies, it will return 
false. The translation is done by: 

SearchRecipe translate (SearchRecipe s. 
Vocabulary v2; 

which returns a Search Recipe in the specified Vocabulary. 
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Chapter 4 Core-Managed Resources 



Clients interact with the e-speak Core by sending messages to Core-managed 
Resources. For example, the Resource Factory is used to register new Resource 
metadata. This Chapter lists all the core-managed resources and describes those 
which are not described in other Chapters. It also describes the internal state that 
is passed if the Core-managed Resource is exported by value to another Logical 
Machine. 



Conventions 

All the methods described in this Chapter throw ESInvocationException (see 
Chapter 7/ Exceptions"), the base class for exceptions thrown by the e-speak Core 
to the Client during message processing. 

Each class, of which instances can be exported by value, starts with a list of static 
declarations. Each declaration contains a permissible content of the payload in a 
PDU (see ) requesting the core to invoke a method in that class. 



The Account Manager Resource 

The Account Manager Resource is for managing user accounts on an e-speak Core. 
A user account contains information about the user including its PSE (Private 
Security Environment) . This enables a user to authenticate to the Account Manager 
(via userid, password) and to retrieve its PSE. In the current implementation it will 
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then need a passphrase to unlock the PSE to access its key material. The placing of 
the PSE under the Account Manager Resource does not implement the SPKI 
requirement for absolute security of private keys (see Chapter 5, * Access Control") . 

User Profile 

The class UserProfile defines the basic information stored by the Account Manager 
for each user. 

class UserProfile{ 
Authlnfo authlnfo; 
String userESURL; 
String userlnf ormation; 
String userType; 

Prof ileAttributeSet preferences ; 

byte[] pse; 

} 

User Identity 

The class Authlnfo defines the basic information used by the Account manager to 
identify a user 

class AuthInfo{ 
String userName; 
String passPhrase; 
String homeAddress; 
} 

The home address indicates the "home e-speak Core of a user" in hostportNumber 
format. An example is: 

myhost .myCo . com: 1234 

User's Account 

The userESURL is the ESName of the user's Account Resource. This is a Protection 
Domain. This ESName is bound to the user s Protection Domain in a Name Frame 
created by the Account Manager Note that this ESName also includes the host and 
portNumber of the user's "home e-speak Core" . An example of a userESURL is: 

es : //myhost .myco. com: 12345/Core/AccountMariager/ 
myho s t . my co . c om : 1 2 3 4 /myName 
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When the Account is registered a Protection Domain is created and registered using 
the Base Account Vocabulary (see in Chapter 3, "Resource Data, Searches & 
Vocabularies") with attributes from Authinf o and UserProf ile. This means the 
Account Resource (Protection Domain) can be discovered using attribute-based 
findO, just like any other e-speak Resource. 

User Type and Information 

UserType and Userlnformation are arbitrary strings that can be assigned by an 
application. These are defined in the BaseAccount Vocabulary, so they can be used 
to find Users. 

Private Secure Environment (PSE) 

The byte array pse is opaque, not interpreted by the e-speak Core. 
Preferences 

The <Prof ileAttributeSet pref erences> field is a set of name, value pairs 
defined as follows. 

class Prof ileAttributeSet { 
AttributeSet attrs ; 

String format; 
} 

If the format string is set to "vocab", the AttributeSet attrs will be defined in a 
vocabulary specifed in the attrVocab field of the AttributeSet (see Chapter 3, 
* Resource Data, Searches & Vocabularies") . Otherwise the format string will be set 
to "simple" and attrs will contain an arbitrary set of name-value pairs, not 
necessarily valid in any vocabulary. 

The ProfileAttributeSet contains secret information. The intent is that this 
information should not to be visible to any application other than the one that 
registered the account. 
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Account Manager methods 

The following methods can be specified in the method field of a 
MessageForResource PDU with AccountManagerlnterface in the interface field. 

public interface AccountManagerlnterface { 
public String registerUser (UserProf ile up) 

throws PermissionDeniedException, StaleEntryAccessException, 
NameNot FoundExcept ion ; 

public boolean unregisterUser (Authlnf o authlnfo, 
String accountName) 

throws PermissionDeniedException, StaleEntryAccessException, 
NameNot FoundExcept ion ; 

public boolean authenticateUser (Authlnf o authlnfo) 

throws PermissionDeniedException, StaleEntryAccessException, 

NameNo t FoundExc ep t i on ; 

public UserProf ile getUserProf ile (Authlnf o authlnfo, 
String accountName) 

throws PermissionDeniedException, StaleEntryAccessException, 
NameNot FoundExc ep t ion ; 

public boolean set0serProf ile (Authlnf o authlnfo, UserProf ile up) 
throws PermissionDeniedException, StaleEntryAccessException, 
NameNot FoundExcept ion; 

public String [] getAllUsers ( ) 

throws ESInvocationException; 

public boolean addDescript ion (Authlnf o authlnfo, 

String accountName, AttributeSet as) 

throws ESInvocationException; 

public String getUserESURL (String accountName) 
throws ESInvocationException; 

} 

The function getAllUsers returns a list of the ESNames (in stringified form) of 
the Account Resource (Protection Domains) of all registered users. 



54 



Developer Release X.03.03.00 f September 2000 



Core-Managed Resources 



Connection manager 



The function addDescr iption is used for adding a new AttributeSet to the user s 
Account Resource (Protection Domain) . This can be in any vocabulary, not just the 
Base Account Vocabulary. 

The accountName parameter in getuserProf ile and getUserESURL must match 
the userName in the Authinf o of the intended account. 

The function getUserESURL returns a String corresponding to the ESNames(URLs) 
of the user's Account Resource (Protection Domain), 



Connection manager 

The connection manager is described in Chapter 6, "Communication". 



Core management resource 

The core management Resource is deprecated in the current release. It may later be 
part of a Management API, and/or be changed. The current methods are: 

interface CoreManagement Interface extends ManagedServicelntf { 

int pingCint pingValue) 
throws ESInvocationException; 

ESName [] getCl ient Connect ions ( ) 
throws ESInvocationException; 

boolean stopServingOutbox (ESName Protect ionDomain) 
throws ESInvocationException; 

boolean stopServinglnbox (ESName Inbox) 
throws ESInvocationException; 

boolean startServingOutbox (ESName Protect ionDomain) 
throws ESInvocationException; 

boolean s t art Servinglnbox (ESName Inbox) 
throws ESInvocationException; 

boolean remove Protect ionDomain (ESName Protect ionDomain) 
throws ESInvocationException; 

boolean denyNewClientSessions ( ) 
throws ESInvocationException; 

boolean acceptNewClientSessions {) 
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throws ESlnvocationException; 

long getTotalMemory ( ) 
throws ESlnvocationException; 

long getFreeMemory ( ) 
throws ESlnvocationException; 

void startJVMGCO 
throws ESlnvocationException; 

void stopJVMGCO 
throws ESlnvocationException; 

void setJVMGCInterval (int millis) 
throws ESlnvocationException; 

int getJVMGCInterval () 
throws ESlnvocationException; 

boolean isJVMGCRunning ( ) 
throws ESlnvocationException; 

void startScavenger { ) 
throws ESlnvocationException; 

void stopScavenger (} 
throws ESlnvocationException; 

void setStatsNum(int num) 
throws ESlnvocationException; 

ESArray 1 getScavengerStats ( ) 
throws ESlnvocationException; 
} 

The Core Management Resource provides a way for a client to manage its core. By 
invoking the Resource on another core it can use the same methods on that too. 
(The client must have appropriate certificates in any case.) The Core Management 
Resource is itself a Core-managed resource: it implements the interface 
ManagedServicelntf described in Chapter 9, "Management" . 

The method ping checks that the core is up and returns the value specified 

The method getClientConnections returns a list of protection domains that 
are currently being used. 

The methods stopServingOutbox and startServingOutbox tell the e-speak core 
to stop or start serving the outbox associated with the protection domain specified. 

The methods stopServinglnbox and startServinglnbox tell the e-speak 
Core to stop or start serving messages to the Inbox specified. 
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The method removeProtectionDomain removes the Protection Domain 
specified. Any client using the Protection Domain is disconnected and any 
Resources contained in the Protection Domain are deregistered. 

The methods denyNewClientSessions and acceptNewClientSessions tells the 
e-speak core to stop or start accepting new connections from clients. 

JVM management methods 

The following methods are specific to e-speak Cores implemented in Java. Some e- 
speak Cores may not implement these methods: if so, the method will return a 
MethodNotlmplemented exception. 

The methods getFreeMemory and getTotalMemory get the free memory or total 
memory in the e-speak Core s Java Virtual Machine (JVM). 

The methods s t art JVMGC ( ) and stop JVMGC ( ) start and stop the e-speak Core's 
JVM garbage collector. 

The methods set JVMGCInterval and get JVMGClnterval ( ) set and get in 
milliseconds the interval between runs of the JVM garbage collector. 

The method is JVMGCRunnirig ( ) returns true if the JVM garbage collector is 
running. 

Scavenger management methods 

The current implementation of the e-speak Core has a scavenger that looks for 
resources in the repository that are no longer valid and removes them. It can 
remove resources even if references to them still exist, unlike the JVM garbage 
collector. Examples of resource that may no longer be valid include the following. 

• Resources registered in a Protection Domain that has been removed. 

• Resources imported from another e-speak Core after the connection to that 
Core is closed. 

Some e-speak Cores may not implement these methods: if so the method will return 
a MethodNotlmplemented exception. 

The methods startScavenger and stopScavenger enable and disable the 
scavenger from running. 
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The scavenger also records statistics for each run as follows. 

class ScavengerStats 

{ 

Int runNo ; 

Long timeElapsed; 

Int numlnspected; 

Int mimCollected; 

Int totalNumlnspected; 

Int totalNumCollected; 

String phase; 

} 

The runNo field indicates the current run (the first run is run number 1) . 

The timeElapsed field is the time taken for the run in milliseconds. 

The field numlnspected indicates the total number of Resources inspected in this 
run. 

The field numCollec ted indicates the total number of Resources removed in this 
run. 

The fields totalNumlnspected and totalNumCollected are the running totals 
since the e-speak Core was started. 

The phase field will contain the string * Mark" or "Sweep" , this denotes whether the 
run was a "mark" or "sweep" run. Resources are only removed from the repository 
(and the numCollected count incremented) on a sweep run. There is no notion of 
"mark" or "sweep" phases on Resources in the cache. 

The scavenger keeps statistics for a certain number of runs. This is set by method 
setstatsNum in the CoreManagementlnterface. The method 
getScavengerStats returns an ESArray of containing an instances of 
ScavengerStats in each element. (The current implementation returns an instance 
of the Java Vector class.) 
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Finder Resource 

The finder, with a principal method 

FinderResults f ind (SearchRecipe sr) 

is discussed in Chapter 3, "Resource Data, Searches & Vocabularies*. It enables 
discovery of Resources matching the SearchRecipe, and optionally putting them in 
an order of preference, by examination of the Resource Descriptions in the 
Metadata. 



Mailbox 

E-speak has both Outboxes and Inboxes, but only Inboxes are exposed to Clients 
as Core-managed Resources. The Core s only actions on outboxes are the 
startServingOutbox ( ) and stopServingOutbox ( ) methods of the 
CoreManagementlnterface. An Inbox is where a Client gets messages from the 
Core. A Client can have more than one Inbox, but each Inbox must be explicitly 
connected by the Client before it can be used to receive messages. 

An Inbox cannot be exported. 

The Inbox class implements the Mailboxlnterface defined below: 
interface Mailboxlnterface 

{ 

boolean isConnected ( ) 
throws ESInvocationException; 

void connect (int slot) 
throws ESInvocationException,* 

void disconnect () 
throws ESInvocationException; 

void reconnect (int slot) 
throws ESInvocationException; 

} 
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An Inbox is a Core-managed Resource that provides a unidirectional 
communication channel from the e-speak Core to a Client. When a Client registers 
a Resource with the e-speak Core, it must assign an Inbox Resource as the 
* Resource Handler* for the Resource. Any service requests directed to the Resource 
are delivered to the Client on the I/O channel associated with the Inbox that was 
named the Resource Handler. 

An Inbox can be in one of the two states: connected or disconnected. Upon 
creation, the Inbox starts in the connected state. The creator of the Inbox becomes 
the owner of the Inbox, and the Inbox is set up to use the I/O channel information 
passed with the request to create the Inbox. The Inbox remains in the connected 
state until the Client requests an explicit disconnect, or until the I/O channel 
associated with the Inbox is closed, at which time it is put in the disconnected state. 
If a Client sends a message to a Resource whose handler is an Inbox in the 
disconnected state, an exception is thrown by the e-speak Core. 

One may argue that Inboxes are unnecessary and that the e-speak Core could store 
the I/O channel information in the Resource Handler field directly. There are two 
main reasons for having the Inbox store the I/O channel information and not the 
Resource- one has to do with Client restart, and the other with delegation. These 
are explained in the following subsections 

Inbox and Client Restart 

In the e-speak environment, a Client can recover from some types of failures, one 
of which is the failure of a Client process. If a Client process dies and restarts, it can 
reconnect to the Core, discover and activate its previous Protection Domain, and 
discover and connect to the Inboxes owned by it. That way it can continue to serve 
the Resources that were registered by it during its previous incarnation. 

Connecting to an Inbox involves updating the I/O channel information maintained 
by the Inbox. Keeping the I/O channel information in the Inbox helps simplify the 
Clients job at restart. It only has to discover and re-connect to one or a few inboxes. 
If, instead, the I/O channel information is stored in all the Resources registered by 
the Client, it would somehow need to be updated all over the place upon 
reconnection by the Client. 
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Inbox and Delegation of Resource Handling 

Under certain circumstances, a Client may want to delegate the handling of one or 
more Resources served by it to another Client. Inboxes make the delegation easy. 
Let's say Client A has registered 100 Resources, and named Inbox IB as its handler. 
After a while, Client A wants Client B to take over the handling of all these 
Resources. This can be achieved as follows: 

1 Client A passes the name of the Inbox IB to the other Client, along with a 
certificate to perform a reconnect operation on the Inbox. 

2 Client B requests the e-speak Core to reconnect it to the Inbox IB. The Core 
replaces Client As I/O channel information with Client B s I/O channel 
information. 

3 Any further service requests directed to any of the 100 Resources are diverted to 
the I/O channel specified by Client B. The process of reconnection is performed 
atomically. Though logically the reconnect operation involves a disconnect 
operation on behalf of Client A and a connect operation by Client B, no one 
really sees the transient disconnected state. 



Name Frame 

A Name Frame manages the bindings of ESNames to Resources. A Client s default 
Name Frame is part of its Protection Domain. This section first describes the 
structure of an ESName and a binding and then describes Name Frames and data 
structures used by Name Frames. 

ESNames 

The only way a Client can refer to a Resource when communicating with the Core 
is to specify an ESName for the Resource. ESNames are defined fully in Chapter 6, 
"Communication" , Section ""ESNames" on page 165". 
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Bindings 

In e-speak, a name is bound to a Mapping Object which consists of an array of 
Accessors. An Accessor can be one of two types, as represented in Table 6. 



Table 6 Mapping Object accessor types and descriptions 



Accessor Type 


Descriptions 


Search request 


A set of attributes, their corresponding values, and a 
Vocabulary to use in interpreting them 


Explicit binding 


A single instance of a Resource 



Thus, a name can be bound to: 

• Zero or more Resources 

• Zero or more Search Recipes 

• Some combination of explicit bindings and search request bindings 

The term simple bindingis applied to a name bound to a Mapping Object that has 
a single explicit binding. The term complex bindingis used otherwise. 

NameSearchPolicy 

A NameSearchPolicy is used when a find request has returned some bindings. 
The NameFramelnterf ace listBindings or listNames methods listed 
below are used with a NameSearchPolicy argument: 

class NameSearchPolicy 

{ 

static final int NSP_ANY = 0; 

static final int NSP^SIMPLE = 1; 

static final int NSP_EXPLICIT = 2; 

static final int NSP__PARTIAL = 3; 
ESName contract; 
int bindingType; 
boolean matchSense; 

} 
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NSP_ANY means match any binding types. NSP_simple means match simple 
binding types. NSP_SXPLICIT means match explicit binding types. NSP JPARTTAL 
means match partial binding types (this is not implemented in the current release, 
and will cause undefined behavior if used). 

If matchSense is false, the meaning of the Name Search Policy is negated, so 
listBindings will return the names of bindings that do not satisfy the Name 
Search Policy. 

Name Frame Methods 

Some NameFrame methods throw ESServiceException. Chapter 7, 
"Exceptions" lists the exception hierarchy for NameFrame methods. 

The NameFrame methods are defined below; 

interface NameFrame Inter face 

{ 

boolean isBound (String baseName) 
throws ESlnvocationException; 

void bind (String baseName, SearchRecipe recipe) 
throws NameCollisionException, QuotaExhaustedException, 
ESlnvocationException, ESServiceException; 

void rebind (String baseName, SearchRecipe recipe) 
throws ESlnvocationException, NameCollisionException; 

void unbind (String name) 
throws ESlnvocationException, InvalidNameException 
QuotaExhaustedException; 

void rename (String oldName, String newName) 
throws ESlnvocationException, ESServiceException 
InvalidNameException, NameCollisionException; 

void copy (String toName, ESName from) 
throws ESlnvocationException, ESServiceException 
NameCollisionException, InvalidNameException, 
StaleEntryAccessException, QuotaExhaustedException; 

void add (String name, ESName from) 
throws ESlnvocationException, InvalidNameException, 
StaleEntryAccessException ; 
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void subtract {String name, ESName from) 
throws ESInvocationException InvalidNameException, 
StaleEntryAccessException; 

String!] listNames (NameSearchPolicy nsp) 
throws ESInvocationException, NameNotFoundException; 

String [] listBindings (String aBaseName, 
NameSearchPolicy nsp, 
ESName target Frame) 

throws ESInvocationExceptionlnvalidNameException, 
StaleEntryAccessException, QuotaExhaustedException; 

A Name Frame can be exported by value or by reference. In the case of export by 
value, the Name Frame state is the bindings ESMap. The serialization for ESMap is 
defined by the e-speak serialization format. ESMap is an ESArray in which the 
convention is that consecutive elements are treated as pairs. In the case of bindings, 
the first element of a pair is the string component of ESName; the second is a 
MappingOb j ect to which ESName is bound. A MappingObject consists of a set of 
SearchRecipes and explicit bindings to resources. The explicit bindings are internal 
pointers (repository handles) to the resource metadata in the e-speak Core s 
repository. A MappingObject is serialized as an ESSet containing the SearchRecipes 
in the MappingObject (explicit bindings are not contained in the serialized form 
transmitted in the case of pass by value). 

All methods that create a new entry in a Name Frame return a Name Collision 
Exception if the name already appears in the target Name Frame. An explicit rebind 
or unbind is required before the name can be reused. 

The isBound method checks to see if the specified name (baseName) is bound in 
this Name Frame. It returns true if the name is bound. 

The method bind binds SearchRecipe to a specified name (baseName) in this 
Name Frame. 

The method rebind changes the binding of the specified name (baseName) in this 
Name Frame to the new SearchRecipe. 

The method unbind removes the binding from NameFrame, 

The method rename renames the binding associated with oldname to newname . 
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The method copy copies the binding of from to toName. 

The method add adds the binding of from to the binding of name to give a new 
binding for name. 

The method subtract subtracts the bindings of from from the bindings 
associated with name to give a new binding for name. 

The method listNames returns an array of strings corresponding to all bindings 
that match NameSear chPolicy nsp. The Name Search Policy allows the Client to 
specify the type of binding and/or Contract in which the Resource is registered. 

The method listBindings lists all the bindings of the argument aBaseName that 
match NameSearchPolicy nsp. These bindings are placed in the NameFrame 
named by targetFrame. The return value is an array of String, each element 
being the name of a new binding in targetFrame. 



Protection Domain 

A Client s Protection Domain is analogous to a user s home directory in an 
operating system. It contains a root Name Frame in which the Client can place 
bindings. 

Each Protection Domain is associated with a quota. The goal of this is to track and 
manage use of space in the Repository. To support this, each Protection Domain has 
three fields associated with it: used, soft limit, and hard limit. A Protection Domain 
is guaranteed to be able to allocate Resources up to its soft limit. A Protection 
Domain may be able to allocate Resources up to its hard limit, depending on the 
memory usage of the Core. The default hard limit is 10,000,000 bytes, and the default 
soft limit is 30,000 bytes. 

A Protection Domain cannot be exported. 

The ProtectionDomain interface is defined below: 

interface ProtectionDomainlnterf ace 

{ 

ESName [] switchPD ( ) 
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throws ESInvocationException, PermissionDeniedException, 
NameNotFoundException StaleEntryAccessException, 
QuotaExhaustedExcept ion ; 

Object [] getQuotalnfoO 
throws ESInvocationException PermissionDeniedException, 
NameNotFoundException; 

Object[] setQuota (long softQuota, long hardQuota) 
throws ESInvocationException, PermissionDeniedException, 
NameNot FoundExcept ion ; 

ESName newProtectionDomain (String name, 
boolean persistent 
) 

throws PermissionDeniedException; 
} 

The method switchPD switches the Client's active Protection Domain to this 
Protection Domain (i.e., the Protection Domain receiving the method invocation). 
It returns an array of two ESNames. Element [0] is the ESName for the old 
Protection Domain, and element [1] is the ESName for the new Protection Domain. 

The Ob j ect [ ] array returned by getQuotalnf o and setQuota contains at least 
three values. The first is Long containing the total number of bytes currently 
consumed in the Core by this Protection Domain. The second is Long containing 
the soft limit in bytes. The third is Long containing the hard limit in bytes for this 
Protection Domain. 

The method newProtectionDomain creates a new Protection Domain. The 
name parameter is the name given when registering the new Protection Domain in 
the default vocabulary. The parameter persistent is set to true, if the new 
Protection Domain is to be made persistent. The return value is the ESName of the 
new Protection Domain. 

The following initial names are defined in the default NameFrame of a new 
Protection Domain: 

XurrentPD" is bound to the Protection Domain itself 

"Core" is bound to the core name frame (es://host/core) (see Chapter 6, 
"Communication" , section on ESNames). 
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Remote resource manager 

The Remote Resource Manager is described in Chapter 6, 'Communication* . 



Repository 

This is described in Chapter 10, "Repository (Informational)". 



Repository View 

A Repository View contains references to a set of Resources. 

When a Client does a find in a Repository View, the Core will attempt to match only 
those Resources included in the view. If no match is found, no accessor is added to 
the Mapping Object. 

A Repository View can be exported by reference or by value. 
The RepositoryView class is defined below: 
class RepositoryView 

{ 

ESName [] Resources ; 

boolean add (ESName res) 
throws ESInvocationException PermissionDeniedException, 
StaleEntryAccessException, NameNotFoundException, 
QuotaExhaus tedException ; 

boolean remove {ESName res) 
throws ESInvocationException PermissionDeniedException, 
StaleEntryAccessException, NameNotFoundException, 
Quo t aExhau s t e dExc ep t i on ; 

boolean contains (ESName res) 
throws ESInvocationException PermissionDeniedException, 

StaleEnt ryAccessExcept ion , NameNot FoundExcept ion ; 
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boolean clear () ; 
throws ESInvocationException QuotaExhaustedException 
Permi s s i onDeni edExcept i on , NameNot FoundExcep t i on ; 

boolean addExternalLookupHandler (ESName res); 
throws ESInvocationException Permi ssionDeniedExcept ion, 
StaleEntryAccessException, NameNot FoundExcept ion; 

boolean removeExternalLookupHandler ( ) 
throws ESInvocationException StaleEntryAccessException 
Permi s s i onDeni edExc ep t i on , NameNot FoundExcep t i on ; 

} 

An externalLookupHandler is not used in this release. Any attempt to use 
addExternalLookupHandler or removeExternalLookupHandler will 
cause undefined behavior. 

In general, all methods return true if they are successful, false if they fail Clients can 
add Resources to and remove Resources from a Repository View. Attempts to add 
a Resource already in a Repository View will fail, as will attempting to remove a 
non-existing Resource. The method clear removes all Resources from the 
Repository View. The method contains returns true if the Resource, res, is 
contained in the Repository View. 
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Resource Contract 

An e-speak Resource Contract is not an agreement between a Client of a Resource 
and the Resource Handler. Instead, it states the interface to which the Resource 
Handler will respond and conform. 

Two Resource Contracts are available at system start-up in addition to those for 
Core-managed Resources. The default Resource Contract allows any Client to 
register a Resource. It is useful for Clients wishing to define Resources that don't 
specify a particular interface, such as Callback Resources. The second Resource 
Contract is for creating new Resource Contracts. 

A Resource Contract contains a type string. This denotes the Resource type that is 
registered in this Resource Contract. A Resource Contract also contains a set of 
Vocabularies that can be used to discover and call upon Resources of this type 2 . 

A Contract can be exported by value or by reference. 

The ResourceContract class is defined below: 

class ResourceContract 

{ 

SSName [] Vocabularies ; 
string type; 

void getVocabularies (ESName tar get Frame) ; 
throws ESInvocationException PermissionDeniedException, 
StaleEnt r yAc cess Exc ep t ion , NameNo t FoundExc ep t i on ; 

The method getVocabularies populates the Name Frame, targetFrame, with 
the names of the Vocabularies supported by the Resource Contract. The Name 
Frame targetFrame is cleared before the operation* 



2 This may be omitted in future releases 
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Resource Factory 

A Client wishing to register a Resource with an e-speak Core uses the Resource 
Factory. This is also used for creating Core-managed Resources. 

The ResourceFactorylnterf ace class is defined below: 

class ResourceFactorylnterf ace 

{ 

void registerResource ( 
ResourceDescription descr, 
ResourceSpecif ication spec, 
Boolean persistence, 
Object param, 
ESName targetFrame, 
String toBaseName 
) 

throws ESInvocationException PermissionDeniedException, 
StaleEntryAccessException, NameNotFoundException, 
NameCo 1 1 i s i onExcept i on ; 

} 

The registerResource method takes a ResourceDescription and a 
ResourceSpecif ication as parameters. If persistence is true, the Core will 
preserve the metadata after the Client's connection is closed, and also the state, in 
the case of a core-managed Resource only. The state of an external Resource is 
never preserved after the Client s connection is closed. The targetFrame 
parameter is the ESName of a Name Frame in which the name for the new Resource 
will be put. The toBaseName parameter is the name of the new Resource in the 
Name Frame. The Object param is intended to hold Resource-specific information 
for creating Core-managed Resources, but is not currently used. It can be of any 
type supported in the e-speak serialization format 
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Every instance of e-speak provides a MetaResource that provides access to 
metadata (Resource Descriptions and Resource Specifications). Once a Resource 
has been registered using a Resource Factory, the only way to access its metadata 
is through a message sent to the MetaResource, using the 
ResourceManipulationlnterf ace defined below. 

MetaResources are not exported. 

interface ResourceManipulationlnterf ace 



void unregister (ESName resource) 
throws ESInvocationException; 

void setResourceOwner (ESName resource) 
throws ESInvocationException; 

ESName getResourceOwner (ESName resource) 
throw ESInvocationException; 

ESName getResourceProxy (ESName resource) 
throws ESInvocationException; 

void setResourceProxy (ESName resource, 
ESName resourceHandler) 
throws ESInvocationException; 

ESName getResourceContract (ESName resource) 
throws ESInvocationException; 

ADR getMetadataMask (ESName target) 
throws ESInvocationException; 

void setMetadataMask (ESName target, ADR mask) 
throws ESInvocationException; 

ADR getResourceMask (ESName target) 
throws ESInvocationException 

void setResourceMask (ESName target, ADR mask) 
throws ESInvocationException 

ADR getOwnerPublicKey (ESName target) 
throws ESInvocationException; 
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void setOwnerPublicKey (ESName target, ADR key) 
throws ESInvocationException 

ESMap getPublicRSD (ESName resource) 
throws ES Invocat ionExcept ion ; 

void setPublicRSD (ESName resource , ESMap rsds) 
throws ESInvocationException; 

ESMap getPrivateRSD (ESName resource) 
throws ESInvocationException; 

void setPrivateRSD (ESName resource, ESMap rsds) 
throws ESInvocationException; 

ResourceDescription getResourceDescript ion {ESName target) 
throws ESInvocationException; 

void setResourceDescription (ESName resource, 
ResourceDescription desc) 
throws ESInvocationException; 

int getEventControl (ESName resource) 
throws ESInvocationException; 

void setEventControl (int setting) 
throws ESInvocationException; 

boolean isPersistent (ESName target) 
throws ESInvocationException; 

boolean isTransient (ESName target) 
throws ESInvocationException; 

void setPersistent (ESName target) 
throws ESInvocationException; 

void setTransient (ESName target) 
throws ESInvocationException; 

ESUID getESUID (ESName target) 
throws ESInvocationException; 

ESName getUrl (ESName target) 
throws ESInvocationException ; 



72 



Developer Release X.03.03.00, September 2000 



Core-Managed Resources 



Resource manipulation 



long getQuota (ESName target) 
throws ESInvocationException; 

ResourceType get Type (ESName target) 
throws ESInvocationException 

ADR getServicelD (ESName target) 
throws ESInvocationException 

void setServicelD (ESName target, ADR id) 
throws ESInvocationException 

} 

All methods can throw PermissionDeniedException, 
StaleEntryAccessException and NameNotFoundException 

The convention for a Resource-specific data (RSD) array is that it consists of a 
sequence of pairs- the first element of each pair is a string used to tag the second 
element. (This is represented in an ESMap, for example in the return from 
getPublicRSD). 

Most of the methods in a MetaResource are for setting or getting the fields of its 
Resource metadata. Some aspects of these methods warrant explanation: 

The unregister method removes (unregisters) the Resource, resource, from 
the Repository. This removes ResourceDescription and 
ResourceSpecif icat ion; no more messages can be sent to the Resource after 
this operation. 

The setResourceOwner method sets the owner of the Resource, resource, to 
the ESName of the calling Client's Protection Domain. 

The setResourceProxy and getResourceProxy methods set and get the 
Resource Handler. 

There is no method for setting the Resource Contract, because this cannot be 
changed once the Resource has been registered. 

The method getQuota ( ) returns the total charge in bytes to the owners quota due 
to that Resource. 
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The methods getMetadataMask and setMetadataMask are used for getting and 
setting the operations for which security is disabled for a particular Resource's 
metadata: anybody can invoke the methods listed in this mask to manipulate the 
particular Resource s metadata. The methods getResourceMask and 
setResourceMask perform the analogous function for the operations supported by 
the Resource itself. 



The user Interface 

This is not implemented in the current release 

interface Userlnterf ace { 
public String getDescription ( ) 

throws PermissionDeniedException, NameNotFoundException? 

public AttributePropertySet getProperties ( ) 

t hrows Pe rmi s s ionDeni edExc ep t ion, NameNo t FoundExc ep t i on ; 

public void mutateProperties (AttributePropertySet props) 
throws PermissionDeniedException, NameNotFoundException; 



Vocabulary 

See Chapter 3, "Resource Data, Searches & Vocabularies". 



Appendix: Method Names 

In messages sent to Core-managed Resources (see Chapter 6, * Communication") 
the method is identified by a string. The following strings are used. 

AccountManagerlnterface 
PF REG I S TERUS ER 
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PF_UNREGISTERUSER 

PF__AUTHENTICATEUSER 

PFJ3ETUSERPROFILE 

P F_S ETUS ER PROF I LE 

PF_GETALLUSERS 

P F_ADDDE S CR I PT I ON 

Connect ionManagerlnterf ace 

OPENCONNECTION 

GETCONNECTIONS 

CLOSECONNECTION 

CLOSECONNECTIONFROMREMOTE 

CoreManagementlnterface 
PING 

GETCLIENTCONNECTIONS 

STOPSERVINGOUTBOX 

STOPSERVINGINBOX 

STARTSERVINGOUTBOX 

S TARTS ERVING INBOX 

REMOVE PROTECT I ONDOMAIN 

DENYNEWCLI ENTS ES S IONS 

ACCE PTNE WCL I ENTS ESS IONS 

GETTOTALMEMORY 

GETFREEMEMORY 

START_JVM_GC 

STOP_JVM_GC 

SET_JVM_GC_ INTERVAL 

GET_JVM_GC_ INTERVAL 

I S_JVM_GC_RUNNING 

S T ART_S CA VENGER 

S TO P_S CAVENGER 

GET_S CAVENGER_S TATS 

SET_NUM_STATS 

Finder Interface 

FIND 

FINDNEXT 

Mailboxlnterf ace 

ISCONNECTED 

CONNECT 

DISCONNECT 

RECONNECT 

S£ S€rVkeIntf (implemented by Core management resource) 
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GETDESCRIPTION 

GE TOWNER 

GETUPTIME 

GETVERSION 

GETERRORCOND I T I ON 

GETSTATICINFO 

COLDRESET 

WARMRESET 

START 

STOP 

SHUTDOWN 

REMOVE 

GETSTATE 

GETVARIABLEENTRIES 

GETVARIABLENAMES 

GETVARIABLEENTRY 

SETVARIABLE 

GETRESOURCEENTRIES 

GETRESOURCENAMES 

GETRESOURCEENTRY 

SETRESOURCE 

NameFrame Interface 

ISBOUND 

BIND 

REBIND 

UNBIND 

RENAME 

COPY 

ADD 

SUBTRACT 
LISTNAMES 
LISTBINDINGS 
NEW_SUB_FRAME 

Protect ionDomainlnterf ace 

SWITCHPD 

GETDEFAULTFRAME 

SETDEFAULTFRAME 

GETQUOTAINFO 

SETQUOTA 

NEW_PROTECTION_DOMAIN 

RemoteResourceManagerlnterface 
EXPORTRESOURCE 

I MPORTRE SOURCE FROMMSG 
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IMPORTRESOURCE 
EXPORTRESOURCEFROMMSG 
UNEXPORTRESOURCE 
UNEXPORTRE SOURCE FROMMSG 
UPDATEEXPORTEDRE SOURCE 
UPDATEEXPORTEDRESOURCEFROMMSG 
UPDATE IMPORTEDRESOURCE 
UPDATE I MPGRTEDRESOURCEFROMMSG 
EXPORTONCONNECTING 

RepositoryViewInterf ace 
ADD 

REMOVE 

CONTAINS 

CLEAR 

ADD_ELOOKUP 
REMOVE_ELOOKUP 

ResourceContract Interface 

REG I STERRE SOURCE 
GETVOCABULARIES 

ResourceFactorylnterf ace 
REGI STER_RESOURCE 

ResourceManipulationlnterf ace 

UNREGISTER 

GETESUID 

SETRESOURCEOWNER 

GETRESOURCEOWNER 

GETRES OURCE PROXY 

SETRESOURCEPROXY 

GETRES OURCE CONTRACT 

GETPUBLI CRSD 

SETPUBLICRSD 

GETPRIVATERSD 

SETPRIVATERSD 

GETRESOURCEDESCRIPTION 

SETRESOURCEDESCRIPTION 

GETEVENTCONTROL 

SETEVENTCONTROL 

I SEXPORTEDBYVALUE 

SETEXPORTTYPE 

GETQUOTA 

GETMETADATAMAS K 

S ETMETADATAMAS K 
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GETRESOURCEMASK 

SETRESOURCEMASK 

GETOWNERPUBLICKEY 

SETOWNERPUBLICKEY 

GETSERVI CE I D 

SETSERVICEID 

ISPERSISTENT 

IS TRANSIENT 

S ETTRANS I ENT 

SETPERSISTENT 

GETXJRL 

GETTYPE 

User Interface (not implemented in the current release) 

GETDESCRIPTION 

GETPROPERTIES 

MUTATEPROPERTIES 

Vocabularylnterf ace 
GETDESCRIPTION 
GET PRO PERT I E S 
MUTATEPROPERTIES 
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Overview 

The basis of e-speak access control is a Public Key Infrastructure (PKI). In the 
remainder of this chapter we assume the reader is familar with the principles of PKI, 
sometimes also known as Public Key Cryptography, There are many texts to which 
the reader can refer [see for example Schneier, Pfleeger, Stallings]. 

All entities in e-speak (users, services, cores etc) are identified by public keys. To 
authenticate an entity we verify it knows the private key corresponding to the given 
public key. No entity should ever intentionally share its private key or give anybody 
access to the private key. 

The means by which a private key is protected is implementation dependent: not 
part of the architecture. It is very important that the private key is held securely, so 
it is not unintentionally made available to others. In the default implementation the 
private key is encapsulated inside a Private Security Environment (PSE) object, 
described below. 

Any entity can create a key-pair. Provided the private key is kept secret, the key-pair 
will be unique to that entity. However, having a key-pair gives you no power in the 
system. It is necessary also to have Certificates stating the access rights issued to 
your public key. 

To decide whether to honor an incoming request a service must decide if the 
accompanying certificate (or certificates) grant access rights for the request. 
Before that, it verifies that the sender of the request knows the private key 
corresponding to the public key in the certificate to which the access rights have 
been given (formally this is the Subject of the certificate). It does this by a 
cryptographic protocol described in Chapter 6, " Communication" . 
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Finally before honoring the request, the service must verify that it trusts whoever 
issued the certificate. It does this by verifying that the certificate has been signed by 
an entity that it trusts. 

Comparison with X.509 Certificates 

The most common use of certificates is in X.509 based infrastructures to link an 
entity's name to its public key (technically the X.509 Distinguished Name). This is 
how certificates are used in the web. A drawback is that, typically, having used the 
certificate to verify the name, a service needs to consult an authorization database 
to determine the access to be granted. 

E-speak certificates are more general than this. They are signed (authenticated 
statements) linking a public key to a Name or a Tag. (Certificates Unking a Name to 
another Name also exist, and are described below.) The word "tag" distinguishes the 
field concerned from an X.509 "attribute", whose function is broadly similar. A Tag 
typically states an access right. Thus to make an access control decision a service 
does the following: 

• Examines the tag in the certificate to see if it grants access 

• Checks the entity making the request knows the corresponding private key 

• Verifies the certificate has been issued (is signed by) an entity it trusts 

X.509 name certificates are issued by entities called Certificate Authorities. To 
avoid confusion with this, in e-speak we refer to entities issuing certificates as 
Issuers. E-speak Issuers can issue either Name or Attribute certificates. 

Another feature in e-speak not found in X.509 is that it implements a split trust 
model. An entity does not have to trust all Issuers equally. It need not trust any given 
Issuer at all. Those it does trust, it may only trust to issue certificates granting 
access to a subset of its operations. 

Conversely, issuing certificates in e-speak is not a reserved prerogative: anyone can 
do it. Whether or not the certificate will grant access to any Resource depends on 
whether the Resource Handler trusts the Issuer for the service in question. The list 
of which Issuers are trusted for what is called Trust Assumptions. This is discussed 
later in this chapter. 
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Derivation from SPKI 

E-speak implements the Simple Public Key Infrastructure (or SPKI) [see RFC 2692- 
2693[ . In addition to the properties already described, SPKI specifies a structure 
and set of operations on Tag and Name certificates. These are used to parse and 
process the certificates when making access control decisions. The processing and 
access control is discussed later in this chapter. Certain tags (e-speak tags) are 
defined that will be checked explicidy by the e-speak infrastructure before an 
access is authorized. However, applications can choose to use any syntactically 
valid SPKI tag. E-speak will check that certificates containing such tags are valid, 
but will not use them for an access control decision. The application will have to 
interpret these non e-speak tags when making access control decisions. Core 
managed Resources will ignore non e-speak tags. 

Certificate Management 

The process by which an Issuer decides to issue a certificate granting access rights 
to an entity is implementation dependent and therefore not part of the architecture. 
The general process would be for entities to register either with some Issuer or with 
a separate Registration Authority (RA). For registration the entity may need to 
provide credentials such as credit card ntimber, social security number, bank 
details, employee ID, user id., and full name. Once the registering body is satisfied 
it will issue a certificate, or give instructions for issue. The registering body may be 
fully automated, or may queue registrations for human inspection. 

A given entity may have several certificates that have been issued to it. If no strategy 
is adopted to structure and manage certificate issuing then there may be very large 
numbers of certificates required. Administrators and operators would find it 
difficult to run e-speak systems, and operations such as access revocation would be 
extremely hard. Hence we discuss and recommend certain strategies for certificate 
management. These are based around familiar concepts such as user-groups (or 
roles), found in several common operating systems. These are not part of the 
architecture. The management strategy practised must reflect the business 
requirements of the deploying organization. 
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Anybody can create a key-pair in e-speak and then register to get an Issuer to issue 
certificates to the public key. There is no notion of a centralized, all powerful, 
trusted Certificate Authority. Instead entities choose which Issuers they trust for 
what. Authentication in e-speak relies on proof of knowledge of the private key: 
there is no centralized authentication service. Hence the e-speak security 
architecture is a global, fully distributed and single sign-on. 



Example of certificate-based Security (Informational) 

Consider the diagram below. Two large ".com" companies are accessing a portal to 
use services provided by the portal. For simplicity we have shown only 3 services. 




The data held by the services may be sensitive, so both companies would like to be 
sure that their employees are accessing the correct portal and services. In addition, 
having made arrangements for access to the portal (and paid fees) , both companies 
might prefer to be responsible for managing their own lists of employees and 
control who can access the portals services. 

From the portals point of view, it probably only wants to deliver services to paying 
customers and only to deliver those services that each customer has paid for. 
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Suppose CO_l has done a deal with the portal to access services A, B and C, and 
CO_2 has done a deal to access service A and C only. Lets further suppose that C0_1 
and CO_2 are each running an Issuer , called Issuerl and Issuer2 respectively. The 
portal configures A and C to trust both Issuerl and Issuer2; it configures B to trust 
Issuerl only. Then CO_l and CO_2 can issue certificates to each of their employees. 
CO_l s certificates will be honored at A, B and C, but C0_2 certificates will only be 
honored at A and C. 

Each time a service sees a certificate from either company that grants access, it 
increments the bill for that company. This leaves each company in control of who 
among its employees gets access to the services for which it has paid. Each 
company is in control of revocation (e.g. if the employee leaves). In addition the 
portal can immediately revoke access to an entire company, by removing the 
company's Issuer from the list of trusted Issuers. 

Each company may want to make sure that their employees are accessing only 
genuine services. To do so CCM's Issuer issues a Tag certificate binding each of 
service A, B and C s public keys to a tag such as : "C0„1 approved". It must then 
ensure that its employees configure their clients to check for this tag before 
accessing the service. Similarly CO_2 s Issuer issues a Tag certificate to services A 
and C conferring an attribute that is meaningful to C0_2. 

Note that this requires very little authorization data to be held and managed by the 
portal. It only needs to remember the public keys of CCM and C0_2 s Issuer. If 
access control were based on authenticating a name and mapping accesses to that 
name, then the portal would have to keep a list of all employees in each company 
that can access any of the services, and which accesses are allowed for each name 
- much more data to manage and maintain. 
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Authorization Data 

The informal structure of an authorization certificate is: 

Certificate header: a constant field starting " (cert " 
Issuer: the public key of the Issuer 

Subject: the public key or the name of the entity granted the 
certificate 

An optional "delegation" field 

Tag: Details of what is authorized 

Optional validity qualification and comment. 

In this structure, it is the tag that requires most attention by client applications. 



Tags 

As e-speak implements SPKI, any valid SPKI tag can appear in a certificate. The 
BNF for SPKI is given in the SPKI BNF Format section. In this section we give some 
example SPKI tags that can appear in certificates and explain the BNF for a tag. 

E-speak defines a set of standard tabs (see "E-speak Authorization Tags" on page 
87), that will be checked automatically by the infrastructure. The examples given 
in this section are not standard e-speak tags, so they would have to be checked 
explicitly by the application. 

An SPKI tag is an S-expression, that is a list enclosed in matching T and ")\ 
The BNF for a tag is: 

<tag> = "(« "tag" <tag-expr>* ■■ ) " ; 
<tag-and> = »{" »*» "and" <tag-expr>+ ") " ; 
<tag-expr> = <byte-string> | <tag-simple> 

I <tag-prefix> | <tag-range> 

I <tag-set> | <tag-and> 

I <tag-star> ; 
<tag-simple> = " (" <byte -string > <tag-expr>* ")" ; 
<tag-prefix> = "(» "*" "prefix" <byte-string> ") " ; 
<tag-range> - "(" "*" "range" <range-ordering> <low-lim>? <up- 
lim>? ")» ; ^ 

<tag-set> = "(" "set" <tag-expr>* »)" ; 

<tag-star> = "(" »*" ») " ; 
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<tag-and> = '■ (" "*" "and" <tag-expr>+ f -i 

< range- or dering>= "alpha" | "numeric" j "time" | "binary" | 

"date" ; 

<up-lim> - <lte> <byte-string> ; 
<low-lim> = <gte> <byte-string> ; 
<lte> = "1" j "le" ; 
<gte> = "g" j "ge" ; 

A tag is a list of lists, with each list denoted by brackets. In its simplest form (tag- 
simple), a tag is simply composed of byte-strings. The access control machinery 
must interpret the meaning of the tag when making an access control decision. The 
following examples are adapted from SPKI examples previously published as 
Internet drafts. An example form for tags applying to a file system is: 

(tag (files <pathname> <access> )) 

An instance of such a tag is: 

(tag (files //ftp . espeak.net/pub/EspeakArch.pdf read}) 

A client presenting a certificate containing the above tag is allowed read access to 
EspeakArch.pdf (assuming authentication was successful). 

<tag-set> field 

Groups of permissions can be granted using the "tag-set" form: 

(tag (files //ftp. espeak.net/pub/EspeakArch.pdf (* set read 
write) ) 

This grants read and write acess to the file. 
<tag-prefix> field 

A set of permissions having a common prefix can be granted using the "tag-prefix" 
form: 

(tag (files (* prefix //ftp . espeak.net/pub/ ) (* set read write)) 
This grants read and write access to any file under the pub directory. 

<tag-star> field 

The "tag-star" form stands for the set of all valid s-expressions and byte strings. 



1 The <tag-and> field is an e-speak specific extension to SPKI. 
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(tag (files (* prefix // ftp.espeak.net/pub/ ) (*) ) 
The above tag grants all permissions on all files under pub. 

(tag (files (*) {*)) 
Note that trailing "(*)" can be omitted. So the above is equivalent to: 

(tag (files)) 

The two last tags both grant all permissions on all files anywhere. 

(tag (*)) 

The above grants all permissions on anything. This might look as though it is 
conferring a lot of power. However, e-speak has a split trust model: the issuer of 
the certificate containing this tag might only be trusted by a single Resource. 

<tag-and> field 

The "tag-and" form is not used in writing a certificate. It expresses the 
authorizations conferred by the set of tags in the following expression. This is 
analagous to a set-intersection operation: the authorization resulting from a "tag- 
and" form will be that satisfying each and every one of the following tags. So it is 
more restrictive than that of any of the tags on its own.This form is used internally 
when authorization depends on more than one certificate. The process is described 
under Tag Intersection. 

<tag-range> field 

The "tag-range" form stands for the set of all byte strings lexically (or numerically) 
between the two limits. The ordering parameter (alpha, numeric, time, binary, date) 
specifies the kind of strings allowed. For example, the following tag indicates the 
authorization to issue purchase orders whose value is less than $5000. 

(tag (purchaseOrder (* range numeric le 5000 ))) 

The following indicates a salary between $50,000 and $100,000 

(tag (salary (* range numeric ge 50000 le 100000))) 
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E-speak Authorization Tags 

E-speak tags are valid SPKI tags that will be checked by the infrastructure. For core- 
managed Resources the e-speak core will check that a valid certificate is presented 
containing a tag that authorizes the operation. For non-core-managed Resources, it 
is assumed that the resource handler will check there is a valid certificate 
containing a tag that authorizes the operation. However, the e-speak core cannot 
enforce this; the resource handler is responsible for Resource security. 

E-speak tags that authorize access to services have the following form: 

(tag (net .espeak. method <interface> <method> <serviceld>) ) 

The following tag authorizes the "stop" operation in the 
serviceManagementlnterface for the identified Resource. 

(tag (net . espeak. method ServiceManagementlnterface stop 
xxxxyyyyzzzz) ) 

The forms tag-star, tag-prefix, tag-set and tag-range can all be used within an e- 
speak tag. So the following tag authorizes operations on the ServiceManagement 
interface in two different Resources. 

(tag {* set (net .espeak. method ServiceManagementlnterface stop 
xxxxyyyyzzzz) 

(net .espeak. method ServiceManagementlnterface (* set stop start) 
aaaabbbbbccccc) ) ) 

The long strings at the end represent the Serviceld, described below. 

The following form authorizes every method on every ServiceManagementlnterface 
on Resources that trust the issuer. 

(tag (net . espeak. method ServiceManagementlnterface (*) (*) )) 
Or equivalently: 

(tag (net . espeak. method ServiceManagementlnterface )) 

The following authorizes any method within the given interfaces (core managed 
Resources) on any object: 

(tag { 
(net . espeak. method 
(* set 

ResourceFactorylnterf ace 
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ResourceManipulationlnterf ace 
ManagedServicelnterf ace 
CoreManagement Int er f ace 
NameFramelnterface 

) 

) 

) 

Lets assume we have an interface called "file" and the servicelD is set to a notional 
path name (a non default value). The following tag authorizes the read operation on 
all files below the pub directory. 

(tag (net . e speak .method file read {* prefix es.espeak.net/pub/ 
))) 

If serviceld's are set to ordered numerical or alphabetical values, then the tag-range 
form may be useful in the <serviceld> portion of a tag. 

Currently we have only defined e-speak tags for the Network Object Model. This 
assumes a set of services with one or more interfaces* each interface containing one 
or more methods. The programming of J-ESI and the interaction with core- 
managed Resources follow this model However, e-speak can support other 
programming models: an XML document exchange model and a direct messaging 
model have both been implemented. The tags used by these models are part of the 
programming models. There are not part of the core architecture, since the core 
does not need to interpret them: the resource handlers do it. 



Service Identity 

The serviceld field in the Resource specification (see Chapter 3, tt Resource Data, 
Searches & Vocabularies") can contain any valid SPKI tag-expression, defined as a 
"tag-expf in the BNF (see "SPKI BNF Formats" on page 109). This tag-expression 
can be set by anybody with a certificate, from an Issuer trusted by the 
, MetaResource, authorizing setServiceld in the MetaResource. The serviceld field is 
delivered to the resource handler with each message for the Resource. 

The service identity is used by the resource handler when verifying standard e- 
speak tags (see "Verifying tags and tag intersection" on page 100). 
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Default Serviceld 

A default assignment is made by the core when it encounters a standard e-speak 
authorization tag without an authorized service id. The format is: 

<serviceld> = "(" "net .espeak . service" <service class> <service 
name> <unique id> " )" 

<service class> is set to the first available value of: 

1. ) The name attribute in the Resource specification contract, if any. 

2. ) The contract type, if any. 

3. ) A 64-bit random no. if neither of the above exists. 
<service name> is set to: 

1. ) The "name" in the Resource description 

2. ) A 64-bit random no., if 1) is not found. 
<unique id> is a 64-bit random no. 

A secure random number generator should be used, so that the probability of 
accidental authorization when the default has been used will be infinitesimal.. 

Advantages of Servicelds 

The serviceld is intended for use by applications to identify services without using 
the Resource name or access path (ESNames). This decouples authorization from 
resource naming and has several advantages: 

• Service ESNames can be changed without affecting authorization 

• Authorization can be revoked by changing a service's identity, without 
changing its ESName 

• In a replicated service replicas can all have the same identity 

• Tag patterns (the "tag-star" form) can be used effectively, limiting the number 
of certificates issued 

None of this is possible using ESName for service identity. 
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Protection of Servicelds 

Service identity plays a crucial role in authorizing access to a service (see "Verifying 
tags and tag intersection" on page 100). It is essential that the setServicelD 
operation source is protected, so that a valid certificate is required to invoke it. 



Names: Userids, Groups.... 

E-speak also supports SPKI name certificates, of two types. In the first place, an 
Issuer can issue a certificate that binds a public key to a name. This has similarities 
to X.509 certificates which bind a public key to an X.509 Distinguished Name. (A 
Distinguished Name is a name in a special format, distinguishing it globally from 
any other name.) 

SPKI name certificates do not restrict the syntax of the name, other than requiring 
them to be a bytestring. Instead, names are scoped by the public key of the issuer. 
Referring back to our example (see "Example of certificate-based Security 
(Informational)" on page 82), both CO_l and CO_2 could have an employee named 
John Doe. Assuming each company had an Issuer that issued name certificates 
binding these names to public keys, the fully qualified name for each John Doe is: 

Public key of CO_l issuer: John Doe 
Public key of CO_2 issuer: John Doe 

Hence the portal (and anybody else) would have no difficulty distinguishing 
between the two instances of John Doe. 

The second type of name certificate binds a name to a name. For example we might 
want to bind John Doe to the name "users". This kind of certificate confers 
membership of the group "users" on the userid John Doe. It can be used to build a 
role- or group- based security model, such as represented below (see "Managing 
certificates (informational)" on page 106). 
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Public keys Names Group name Services 

Name- Name- Authorization 

KEY: Public Key Name certificate 
certificate certificate 

The algorithm which relates a public key to an authorization in this case is 
described below (see "Name Reduction" on page 97). [See also RFC 2693[ 



Certificate Structure 

The two kinds of certificates in e-speak are Authorization Certificates that bind a 
tag to a public key or a name and Name Certificates that bind a name to a public key 
or a name. The following sections describe and explain the BNF which specify these 
types. 

Some general features of the specification are: 

Nearly every field begins with its name as a literal string. 

* is used to mean "0 or more cases of the preceding field" 

* is also used to mean "anything valid" in the tag-star field described above 



Developer Release X. 03.03. 00, September 2000 



91 



Certificate Structure 



Access Control 



+ means "one or more instances of the preceding field" 
? means the preceding field is optional 
"uris" means a field with one or more URI s. 

The full SPKI BNF is given at the end of this Chapter (see "SPKI BNF Formats" on 
page 109). 

Authorization Certificates 

The format for an authorization certificate is: 

<cert> = "(" "cert" <version>? <cert-display>? 

<issuer> <issuer-inf o>? 

<subject> <subject-info>? 

<deleg>? 

<tag> 

<valid>? 

< comment >? ; 

The optional <version> field defines the <version> of the certificate. The optional 
<cert-display> field is designed to provide hints for display. Neither of these fields 
is used in the current version of e-speak; the parser will ignore them. 

Issuer field 

The <issuer> field is the public key of the Issuer issuing the certificate; it is defined 
as follows. 

<issuer> = "(" "issuer" <principal> ; 
<principal> - <public-key> | <hash-of -key> ; 
<hash-of -key> = <hash> ; 

<hash> = "(" "hash" <hash-alg-name> <hash-valuexuris>? ") " ; 
<hash-alg-name> = "md5" j "shal" | <uri> ; 
<hash-value> = <byte-string> ; 

<public-key> - "(" "px±>lic-key" <pub-sig-alg-id> <s-expr>* 
<uris>? ")" ; 

<pub-sig-alg-id>= "rsa-pkcsl-mdS" | "rsa-pkcsl-shal" | "rsa- 
pkcsl" | "dsa-shal" | <uri> ; 

The <issuer-info> field is intended in SPKI to provide a list of one or more URIs for 
certificates from which the Issuer derives its authority to issue the certificate. This 
is to support delegation: one Issuer may issue a certificate to another Issuer with 



92 



Developer Release X. 03, 03. 00, September 2000 



Access Control 



Certificate Structure 



the delegation field present. (It is the literal "propagate".) Suppose a service trusts 
the first Issuer directly, and not the second Issuer. If a client presents a certificate 
issued from the second Issuer, the service will need to see the delegate certificate 
conferring the privilege on the second Issuer before it authorizes access. The URIs 
would specify the location of delegate certificates. This is not used in the current 
version of e-speak. Instead, the required supporting certificates are obtained during 
the Session Layer handshake (see Chapter 6, "Communication"). The parser will 
ignore this field. 

The "hash-alg-name" and "pub-sig-alg-id" fields identify algorithms used for hashing 
and for signature verification - usually the literal abbreviated algorithm names 
given. The "uri" alternative in each case could be used to give a URI of some other 
algorithm. 

Subject field 

The <subject> field denotes the entity to which the certificate is issued. 

<subject> = "(■ "subject" <subj-obj> ")" ; 

<subj-obj> = <principal> | <name> | <object-hash> ; 2 

<principal> = <public-key> | <hash-of -key> ; 

<name> = <relative-name> | <full-name> ; 

< relative- name > = "(" "name" <byte-string>* »)" ; 

<full-name> = "(» "name" <principal> <byte-string>* ")» ; 

The <subject> is either a public key, a name or the hash of an object. If the subject 
is a public key, then the entity presenting the certificate must prove possession of 
the corresponding private key before authorization is granted. This uses the 
cryptographic protocols described in Chapter 6, "Communication". 

If the <subject> is a name, then authorization is granted to the entity that has a 
certificate binding that name to its public key (see "Name Certificates" on page 96). 
Several certificates may be required to prove this. For example the authorization 



2 The definition here departs from SPKI slightly. SPKI defines <subj-obj> = <principal> | 
<name> | <object-hash> | <keyholder>; E-speak does not support <keyholder>. If the 
parser encounters a keyholder field, it will throw an exception. Which exception depends 
on the point from which it is invoked. One of the e-speak exceptions specified in Chapter 
7, "Exceptions" will be thrown. 
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certificate may be issued to a name such as "users". The name "users" may be 
conferred on another name "John Doe", a real world person. So to get authorization 
three certificates are needed: 

♦ A certificate binding John Doe s public key to his name 

♦ A certificate binding John Doe to the name "users" 

♦ A certificate granting the authorization to "users" 

John Doe needs to prove possession of the private key corresponding to the public 
key in the first certificate using the protocols described in Chapter 6, 
"Communication* The algorithm for name reduction to arrive at the certificate 
binding the name to a key and handling compound names such as <public key: 
"John Doe" "Favorite People"> is described below (see "Name Reduction" on page 
97). 

<relative-name> and <full-name> 

A <relative-name> is assumed to have been issued by the Issuer whose public key 
is in the issuer field. In contrast, a <full-name> is a fully qualified name, explicitly 
scoped by the public key of the Issuer which conferred it. This principle is extended 
for names "issued by" names [see Compound iVames below]. The use of qualified 
names allows any Issuer to issue certificates to names that have been issued by any 
other Issuer, 

<object-hash> (Informational) 

An <object-hash> is intended for the issue of authorization certificates to entities 
such as files and executables. The tag in such a certificate might describe a property 
of the file or the executable. This is not used in the current version of e-speak. The 
parser will ignore the field. 

<subject-info> (Informational) 

The optional <subject-info?> field is defined as follows. 

<subject-inf o> = "subject- info" <uris> " ) " ; 
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The intent of this field is to provide a list of URIs that provide information about the 
subject. For example if the subject is a hash of a key, it might provide the location 
of the key being hashed. If the subject is a name, it might provide the location of the 
name certificates. This field is not used in the current version of e-speak. The parser 
will ignore it. 

Delegation field 

The optional <deleg> field is defined as follows. 
<deleg> = "propagate" 

If this field is included in a certificate, then the subject is authorized to delegate the 
authorization specified in the certificates tag. The subject does this by issuing 
certificates containing the tag, or a subset of the tag s privileges. This is discussed 
further under Delegation. 

Validity field 

The optional <valid> field is defined as follows. 

<valid> = <valid-basic> <online-test>* <restrictions> ; 
<valid-basic> = <not-bef ore>? <not-af ter>? ; 
<not-after> = " (" "not-after" <date> ; 
<not-before> = "not -be fore" <date> ")" ; 

<date> = <byte-string> ; 

If the valid field is missing, the certificate is assumed to be valid without constraints. 
The fields <online-test> and <restrictions> defined in [ Working Draf^ are not 
supported in the current version of e-speak; the parser will ignore them. The <valid- 
basio field is used to support time-based revocation, as described under 
Certificate Revocation. 

A <date> field is an ASCII byte string of the form: 

YYYY-MM - DD_HH : mm : SS 

This is always UTC. For example, "1997-07-26_23:15:10" is a valid date. So is "2001- 
01-01_00:00:00'\ "MM" is a two digit integer in the range 1 to 12; "mm" and "SS" are 
two-digit integers in the range 0 to 59. 

The optional comment field is defined as follows: 
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<comment> = n (" "comment" <byte-string> ")" ; 

Anything is this field is intended to provide information to humans. It is ignored by 
e-speak. 

Name Certificates 

The format for name certificates is: 

<name-cert> = "(" "cert" <version>? <cert-display>? 

<issuer-name> <issuer-inf o>? 

<subject> <subject-info>? 

<valid> <comment>? ") " ; 
<issuer-name> = "(" "issuer" " { " "name" <principal> <byte- 
string> ") " ") " ; 

<principal> = <public-key> | <hash-of -key> ; 

The characteristic feature of a name certificate is the the <issuer-name> field. This 
defines the issuer of the certificate plus the name of the certificate holder. "Issuer- 
name" does not mean "name of issuer". The byte-string in this field is the certificate 
holder's name, and the <principal> is the issuer's public key, or a hash of it. In the 
latter case, there may be a following field containing a URI of the full key, but this 
is not currently used or supported in e-speak. 

Public Keys 

An example of a public key is: 

(public -key 

( r s a - pkc s 1 - md5 
{e #03#) 
(n 

| ANHCG85 jXFGmicr3MGPj 53FYYSYlaWAue6PKnpFErHhKMJa4HrK4WSKTO 
YTTlapRznnELD2D7 1 Wd3 Q8 PDO lyi IN JpNsMkxQVHrrAnlQoc zeOZui z /y Y 
VDzJlDdiImixyb/ayme3D0UiUXhd6VGAz0x0cgrKefKnmjy410Kro3uVfl | 

))) 

The long string between "|" s is a number encoded in base64 notation for relative 
brevity. This is a feature of BNF advanced syntax [see BNF Notation below]. 

Such items may have to be written in certificates, but in the following text, we use 
"PK XXX" as an abbreviation for "XXX s public key". 
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Example 

Taking the example (see "Names: Userids, Groups...." on page 90) , the following 
certificate could be issued by CO_l's Issuer. 

(cert Certificate A 

(issuer ( name (PK CO 1) "John Doe n ) ) 
(subject (PK John Doe) ) 
(not-after ,t 2001-01-01_00 :00 :00" ) 

) 

The underlining is referred to in the next paragraph. 

Name Reduction 

The objective of name reduction is to reduce the name that appears in a subject field 
to a single public key, a <principal>. Name reduction replaces the name in a subject 
field, by rewriting it with the subject field from the corresponding name certificate. 
It uses the fact that a fully qualified name in a subject field has the same format as 
<principal> <byte-string> in an issuer-name field. For example, given Certificate 
A above, suppose there is an authorization certificate: 

(cert 

Certificate B 

(issuer PK X) 

(subject (name (PK CO 1) "John Doe")) 

(tag (net . espeak. method CoreManagement Inter face )) 

) 

The two underlined fields being the same, we can replace <subject> in B by 
<subject> in A, giving certificate C: 

(cert 

Certificate C 

(issuer PK X) 

{subject (PK John Doe)) 

(tag {net .espeak. method CoreManagement Int erf ace )) 

) 
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Compound Names 

Suppose an entity "Editor" issues a name certificate to "Foreign Desk"; and this 
entity in turn issues one to "Paris Correspondent". Each will have PK holder as its 
Subject. An authorization certificate could be made out as follows: 

(cert 

(issuer PK Accounts) 
(subject {name (PK Editor) "Foreign Desk" "Paris Correpondent " 
(tag (Dinner_Expenses (*range le 200) (currency FF) ) 3 

) 

The subject field is a Compound Name. Accessing the name certificates implied in the 
subject field from left to right, we replace this field successively by: 

(subject (name (PK Foreign Desk) "Paris Correspondent) 
(subject (PK Paris Correspondent) ) 

- yielding a certificate which can be authenticated. 

Name reduction is defined formally as part of the tuple reduction rules in [SPKI 
theory, RFC 2693[ . This also includes an algorithm for combining validity fields. If 
the validity fields are dates (as in the current e-speak implementation), then 
informally we take the latest <not-before> date and the earliest <not-after> date. If 
the <not-after> date obtained in this way is before the <not-before> date, then the 
reduction has failed. 

Wire format for certificates 

The "on-the-wire" format for certificates is the BNF Canonical Syntax (see "SPKI 
BNF Formats 1 ' on page 109). 



Delegation 

E-speak supports SPKI delegation. If an Issuer is not trusted directly by the entity 
checking the authorization, its certificates cannot effectively authorize more than 
the delegate certificate authorizes. The SPKI certificate reduction rules [see 

3 Not an e-speak tag. 
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RFC2693 - AIntersect\ describe formally how this is enforced. Informally, it is done 
by intersecting the authorizations specified by all tags in the delegation chain, and 
taking the smallest validity period as decribed in the Name Reduction section. 

Consider the following certificate. 

(cert 
(issuer PK X) 
(subject PK Y) 
(propagate) 

(tag (net .espeak. method CoreManageraent Interface )) 
(not -after "2 000-10-01_00 : 00 ; 00 M ) 

) 

Suppose Y now issues a certifcate to Z as follows, 

(cert 
(issuer PK Y) 
(subject PK Z) 
(tag (net .espeak. method )) 
(not-after M 2001-01-01_00 : 00 : 00") 

) 

Here Y is attempting to authorize more, for longer than was contained in the 
certificate issued to it by X. 

Suppose an entity, checking that Z is authorized, trusts X directly, but not Y. The 
two certificates above form the delegate chain by which Z is obtaining its power. 
The entity intersects the two tags (as described below) , combines the validity times 
(as described above) and rewrites the issuer field according to the reduction rules 
described in [RFC2693[ to get the following certificate. 

(cert 
(issuer PK X) 
(subject PK 2) 

(tag (net . espeak. method CoreManagementlnterf ace )) 
(not-after "2000-10- 01_00 : 00: 00 B ) 

) 

Hence it is not possible for Y s certificate to authorize more for longer than the 
original certificate granted to Y by X, from entities which don't trust Y directly. 
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Verifying tags and tag intersection 

Tag verification is the process of determining whether the set of certificates 
presented contain the required authorization. SPKI tags define sets of 
authorizations. For example the following tag authorizes all methods on all 
instances of the CoreManagementlnterface. 

(tag (net . espeak. method CoreManagementlnterface )) 
So the above tag "contains" the following tag (xxxxyyyyzzzz is the servicelD). 

(tag (net . espeak. method CoreManagementlnterface ping 
xxxxyyyyzzzz) ) 

Appending elements to the end of a tag reduces the set of authorizations specified. 
So: 

(tag (net .espeak. method CoreManagementlnterface ping)) 
specifies less than 

(tag (net . espeak. method CoreManagementlnterface )) 
In the case of a delegation chain, where the successive certificates authorize: 

1 services A, B, C 

2 services B, C, D 

3 services B, D, E - 

the only service authorized will be B - the only member of the "intersection" of the 
three certificates. 

Implementing Verification 

In e-speak, each time an object receives a request to invoke a method, the security 
infrastructure will check that there is a certificate that contains the tag needed to 
invoke the operation. For Core-managed Resources the security infrastructure is 
contained in the core. For other Resources, it is part of the Resource. The security 
infrastructure is part of the current implementation of J-ESI, and clients can use the 
security infrastructure API's for their own resource handlers. 
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For example, if an attempt is made by a client to invoke the "ping" operation on a 
CoreManagementlnterface, the infrastructure will check that there is a certificate 
that contains the tag (tag (net.espeak.method CoreManagementlnterface ping 
xxxxyyyyzzzz)), where xxxyyyzzz is the servicelD of the service being invoked. 

For this to work the infrastructure must know the servicelD of the Resource. The 
servicelD is part of the Resources metadata, and the core presents the servicelD 
with each request. It is trusted to present the correct servicelD. 

For a certificate to authorize an operation we also have to check that the certificate 
is issued by somebody trusted to authorize the particular operation on the 
particular Resource [see Trust Assumptions section]. This means checking the 
public key of the issuer and the signature of the certificate. It is done automatically 
by the security infrastructure. 

Authorization certificates can be issued to names as well as public keys. If a 
certificate issued to a name is presented that authorizes the operation, the name 
must be reduced to the public key of the invoker, as described in the Name 
Reduction section. The invoker s public key will be authenticated by the protocols 
described in Chapter 6, Xommunication*. 

Authentication of Services (Informational) 

In addition to the e-speak tags specified in the E-speak Authorization 7a#ssection, 
a client or service can ask for application-specific tags to be checked, by invoking 
the security infrastructure APIs. Since no e-speak tags are specified for servers to 
present to clients, any authentication of the service by the client will be application- 
specific. For example a client might check for a tag identifying the Id. of a service, 
such as: 

(tag (netespeak.servicelD xxxxyyyyzzzz)) 

This means that the server will have to get a certificate issued to it containing this 
tag. See the Certificate Issuers and Registration section below. 

The security APIs for checking application-specific tags are outside the 
architecture. They are application-specific, and no application-specific tags are 
supported for core-managed Resources. 
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Disabling Security 

This is done by sets of tags called "masks" in the ResourceSpecification (see 
Chapter 3, "Resource Data, Searches & Vocabularies*. Two masks occur in the 
ResourceDescription: 

The Metadata mask, which disables security on methods in the 
ResourceManipulationlnterface. 

The ResourceMask, which disables security on methods in an interface of the 
Resource being specified. 

The basic method tag format is 

(net . espeak .method <interface name> <method name>) 

In the metadataMask the interface name is the core interface being specified, and 
the method name is the operation in that interface. For metadata this will be be the 
ResourceManipulationlnterface, and the method name one of its methods. For the 
resourceMask the interface name will be one of the interfaces supported by the 
Resource. 

In the resource mask for an external Resource the interface name is the fully- 
qualified name of the interface class. For a Core-managed Resource, the interface 
name is not qualified, so we just have "NameFramelnterface" and 
"ProtectionDomainlnterface* etc. The method name is the name of the method in 
the interface, plus the concatenated argument types. This allows overloaded 
methods to be distinguished. 

The metadata mask is used by the in-core metaresource when performing metadata 
operations. The resource mask is passed to the service handler by the core for the 
service handler to use when performing operations on the service itself. 

The masks are completely general tags, so the mask tag itself, or any of its fields, 
may use the tag matching features such as sets, prefixes and ranges. The interface 
and method names, for example, do not have to be string literals, they can be sets 
or prefixes. 

This tag masks method foo in interface net.espeak.examples.Examplelntf: 

{net . espeak. method net . espeak. examples . Examplelntf foo) 
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This tag masks method foo in interface net.espeak,examples.Example!ntf and 
method bar in interface net.espeak.examples.Example2Intf 

{net . espeak . method ( *set 

( net . espeak . examples . Examplelntf foo) 

(net . espeak. examples .Example2 In tf bar) 

This tag masks all methods beginning with foo: 

(net . espeak. met hod net . espeak . examples . Examplelntf (* prefix 
foo)) 

This tag masks methods foo and bar: 

(net .espeak. method net . espeak . examples .Examplelntf (* set foo 
bar)) 

To mask methods with prefix foo or bar: 

(net .espeak. method net . espeak. examples . Examplelntf 
(* set (* prefix foo) (* prefix bar))) 

To mask all methods in the interface: 

(net . espeak. method net . espeak . examples . Examplelntf ) 
This is equivalent to 

(net , espeak .method net . espeak. examples . Examplelntf (*)) 

since missing trailing elements match anything. 

To mask methods foo in InterfaceA and bar in InterfaceB: 

(* set (net .espeak. method InterfaceA foo) 
(net . espeak. method InterfaceB bar)) 

To mask all methods: 

(net . espeak . method) 
or simply 

(*) 
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Certificate Issuers and Registration (Informational) 

There is no restriction in e-speak on who can issue a certificate. Anything that has 
a public key can do it. A certificate gets its power either from trust in the Issuer, or 
from a delegation chain down from a trusted Issuer. If the issuer is not trusted 
directly by a service and has no delegate certificate, its certificates will not 
authorize access to that service. 

The processes of issuing a certificate and of deciding to issue one are application- 
specific: not part of the architecture. In some applications an entity may have to 
undergo a registration process whereby some real-world characteristics are 
verified (credit card numbers, social security numbers and the like). Registration 
may be fully automated, or it may involve human inspection. 

Service Ids. 

Problems can arise if services have the same service identity, either accidently or 
deliberately. For example, a service might use a fake serviceld and ask someone to 
issue privileges for that serviceld. The issuer would then think it was issuing 
privileges on the fake service, when in fact it was issuing privileges on the real 
service. To avoid these problems, anyone claiming ownership of a serviceld must 
be required to produce a certificate granting it to them. This prevents serviceld 
spoofing. 

Unique service identies can be enforced by all Issuers knowing all previously issued 
service identites, or having the Issuer itself generate and issue a cryptographically 
secure and unique service identity in a certificate, or by relying on the service 
identities generated by e-speak, using a cryptographically secure random-number 
generator. 

Note that sometimes we may want to have the same identity for multiple services. 
For example, the services might be replicated. So, whether service identities are 
required to be unique and how this is enforced is not part of the architecture. 
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Trust Assumptions (Informational) 

The basis for establishing trust assumptions is: 

• Who you trust and for what. 

• The importance of protecting this information from tampering. 

• The need to conceal or to reveal who you trust. 

All this is application specific, and trust assumptions are not part of the e-speak 
core's architecture. 

Trust assumptions define whose certificates will be honored, and the acceptable set 
of tags in each case. Both clients and services may have trust assumptions. Trust 
assumptions do not appear in any of the e-speak protocols (core to core, or client 
to core APIs). 

It may be important for a client or server not to reveal certain trust assumptions, 
containing information of potential use to an attacker. Conversely, a trust 
assumption might need to be broadcast, for example to let potential (paying) 
clients know the Issuer they need to get a certificate from, to access a service. 

It is essential to prevent unauthorized tampering with trust assumptions, so that 
attackers cannot add themselves to the list of trusted entities. 

The current implementation uses self-issued certificates to store trust assumptions. 
A certificate is only accepted as a trust assumption if it is self-issued. The format of 
trust assumption certificates in the current implementation of e-speak is exactly 
like that of an authorization certificate. The client or service must distinguish 
between authorization certificates and trust-assumption certificates. This should be 
easy: authorization certificates will be exchanged between two entities as part of 
the message protocols (see Chapter 6, * Communication"). Trust assumption 
certificates will probably be stored locally on disk. They should in any case be 
separate from authorization certificates. 

The following certificate authorizes the entity Certificatelssuer to issue certificates 
authorizing any method in the CoreManagementlnterface. 

(cert 
(issuer PK self) 
(subject PK Certificatelssuer) 
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(tag (net . espeak. method CoreManagement Inter face )) 

) 

The following certificate means the entity trust itself to issue any certificate. 

(cert 
(issuer PK self) 
(subject PK self) 
(tag (* )) 

) 

Note that trust assumptions can use names or public keys as subjects. 



Certificate Revocation 

In the current implementation the only supported means of expressing validity is 
time (the <valid-basic> element). Once a certificate is issued it is valid until it 
expires. 

SPKI supports online tests for validity. Future releases of e-speak will probably do 
the same, and support the principle of a certificate revocation list (CRL). 



Managing certificates (informational) 

The current implementation of e-speak has a Certificate Issuing Service (CI) that 
can be used to issue certificates authorizing access to services that trust it This CI 
might be used to manage access to a set of services on a set of e-speak cores. Here 
we outline the way in which the CI manages its certificates as a guideline to those 
who may wish to implement their own CL 

The CI implements a notion of users and groups. When a user registers with the CI, 
this service issues a name certificate binding the user's name (userid) to a public 
key. Thereafter all certificates are issued to the userid rather than the user's public 
key. This means that to revoke all access to a user we need only revoke the 
certificate binding the userid to the public key. 
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The CI also maintains a list of groups analagous to the groups you might find used 
in operating system security architectures (e.g. "users" and "administrator"). An 
operator of the CI can create new groups. To add a user or users to a group, the 
operator selects the userid or userids and group. The CI then issues a name 
certificate to each user, binding the userid name to the group name. 

To issue authorization certificates for a service, the CI needs to know what 
interfaces and methods are available on the service (the client stub is used for this) . 
The CI presents a simple GUI listing the methods for each interface as well as listing 
groups and userids. The operator can select the group or individual user and what 
interfaces or methods they will be allowed to access. The CI issues an authorization 
certificate to the userid or the group. 

Whenever the CI issues a certificate, it records this in its policy database. The policy 
database is used to drive access revocation and certificate renewal 

The CI provides a certificate directory interface from which stored certificates can 
be retrieved. This allows services to see what certificates have been issued to users 
and permits users to retrieve certificates that have been issued to them. 

Revoking and Renewing certificates 

A certificate is valid until it expires. To save having to renew all certificates 
frequently, an Issuer might choose a relatively short period of validity when issuing 
name certificates binding a user's name to a public key. Other certificates, 
particularly authorization certficates would have longer periods of validity. 

The policy for certificate renewal, enforced by the CI, is to renew automatically all 
certificates in its policy database as they approach expiry. Renewed certificates can 
be retrieved from the CI's certificate directory. 

If a CI operator revokes access or removes a user, the certificate (s) are removed 
from the policy database immediately. This means the certificates will not be 
renewed and can no longer be retrieved from the directory. Entities that have 
retrieved certificates from the certificate directory may continue to use them until 
they have expired. 

Note that all a user's power is revoked as soon as the certificate binding their name 
to a public key expires. 
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Renewing keys 

The CI supports key renewal by issuing a certificate binding the user's new key to 
the user's name. All other certificates issued to the user will remain valid as they are 
issued to the user s userid (name). The user may have to undergo a process similar 
to registration to convince the CI that the new key is valid. 



Private Security Environments (Informational) 

Private keys must never be shared and so need to be stored securely. How private 
keys are stored is a matter for the owner of the key and has no impact on the e-speak 
protocols or APIs used to interact with the core. It is therefore not part of the 
architecture. In the current implementation a PSE or Private Security Environment 
is used. This stores the keys in an encrypted file on a disk. 

The private keys are never revealed to the the application. Instead data is sent to the 
PSE object when it requires signing. The PSE framework has been designed so that 
the underlying mechanisms can be changed to accomodate devices like smart 
cards. 



Interoperability with X.509 (Informational) 

X.509 certificate infrastructures [see RFC 2459\ are becoming more and more 
common. An X.509 certificate binds an entity's distinguished name to its public key. 
This is very similar to the way in which a SPKI name certificate binds a name to a 
public key. One difficulty is that in SPKI the Issuer is denoted by a public key. In 
X.509 the Certificate Authority is denoted by a "distinguished name". Its public key 
is not required to be in the certificate. When it isn't there, the Certificate Authority 
is assumed to have a well-known public key. 
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An e-speak CI can take an X.509 certificate, verify it (check it is signed by a trusted 
Certificate Authority) and issue an e-speak Name Certificate binding an encoding of 
the subject's X.509 distinguished name to the subject's public key. (This is not 
supported in the current release.) 

In addition the e-speak certificate verifier could be extended to handle X.509 name 
certificates natively, automatically converting them to SPKI name certificates as 
outlined above. (This is not supported in the current release.) 

X.509 version 3 also supports attribute certificates and work is on going within the 
IETF on defining a profile for attributes to use within the Internet s PKIX 
infrastructure. It is not possible to define a useable mapping from X.509 attribute 
certificates into SPKI authorization certificates, as X.509 attributes can be arbitrary. 
In principle it should be possible to define a mapping from SPKI certificates into 
X.509 attribute certificates. 



SPKI BNF Formats 

E-speak uses two BNF syntaxes. The "advanced" syntax is used for manually-input 
data and human reading. It has been used throughout this document. Its advantages 
for this purpose are allowing white spaces (including line-feed) , and base64 and hex 
codings of numbers. The base64 coding allows public keys to be written with 
relative brevity. 

The parser accepts certificates in advanced syntax or canonical syntax, and outputs 
them in canonical syntax. This is used for all internal operations, such as protocol 
exchanges, and for serialized transmission. All hashes are computed on data in 
canonical syntax. This is necessary, because varying numbers of white spaces 
would produce invalid hashes. 

Advanced Syntax 

The advanced syntax follows. Its initial non-terminal is <s-part>. 
<alpha> - [a-zA-2] ; 

<base64> = "##" (<base64-char> | <space>}* ; 
<base64-char> = <alpha> | <digit> j [+/=] ; 
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<bytes> = <token> | <string> [ <raw-bytes> | <quoted-string> | 
<base64> | <hex> ; 

<byte~string> = <di splay- type >? <bytes> <decimal> = [0-93+ ; 
<digit> = [0-9] ; 

<di splay- type > = " [ w <bytes> "] " ; 

<hex> = n #|" {<hex-digit> | <space>}* "|"; 

<hex-digit> = [0-9A-Fa-f] ; 

<punctuation> = [\-. /_:*+*] | [' \@] \ [$%"&\ [\] #"<>?: | ] ; 
<quoted-string> = »#<» {delimiter char c} {delimiter string s 
not containing c} {c} 

{any character strng not containing s} {s} ; 
<raw-bytes> = "#'» <decimal> {binary byte string of that 

length} ; 

<s-expr> = "(" (<s-part> j <space>) * ; 
<space> * [ \t\r\n]*,* 
<s-part> = <byte-string> j <s-expr> ; 
<string> = "\" M {string chars} «\«« ; 
<token> = (<alpha> | <punctuation>) 
{<alpha> I <punctuation> | <digit> )* ; 

We also allow end-of-line comments indicated by { . Comments are treated as white 
space. 

Within a string C conventions may be used, including octal escape sequences. 
Specifically: 

\b backspace (010) 
\f formfeed (014) 
\n newline (016) 
\r return (015) 
\t tab (011) 
\nnn octal escape 

Where nnn is a 3-digit octal numeric in the range 0 8 - 177 8 , which is 0 10 - 127 i0 
Canonical Syntax 

The canonical syntax defines the following. 

<bytes> = < raw- bytes > ; 
<decimal> = [1-9] [0-9]* | "0" ; 
<s-expr> = n { " <s-part>* ")" ; 

This disallows space in lists, all byte forms except counted string, and insists that 
decimal numbers have no redundant leading zeros. Hashes are always computed 
over canonical forms. 
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Within certificates, lists must start with a byte string and be non-empty: 

<s-expr> = "{" <bytes> <s-part>* ")" ; 

The following is the BNF currently recognized. The top-level non-terminals are: 

_ <cert>: a certificate. 

_ <name-cert> : a name certificate 

_ <proof> : a certificate justification. 

<proof> is used in the messaging protocol. (See ] 

In the messaging protocol (See Chapter 6, "Communication") we use tag lists for 
queries and requirements. 

<cert> = "(" "cert" <version>? <cert-display>? 

<issuer> <issuer~inf o>? 

<subject> <subject-info>? 

<deleg>? <tag> <valid>? <comment>? " )" ; 
<cert-display> = " ( " "display" <byte-string> " ) " ; 
<comment> - " (" " comment " <byte~string> M ) " ; 
<date> - <byte-string> ; 
<date-expr> « <byte-string> ; 
<deleg> = " (" "propagate" ") " ; 

<full-name> = "(" "name" <principal> <byte-string>+ ; 
<gte> = "g" | "ge" ; 

<hash> = "(" "hash" <hash-alg-name> <hash-valuexuris>? " )" ; 

<hash-alg-name> = "md5" | "shal" | <uri> ; 

<hash-of -key> - <hash> ; 

<hash-value> = <byte-string> ; 

<issuer> = "(" "issuer" <principal> ")" ; 

<issuer-inf o> = " (" "issuer-info" <uris> ")" ; 

<issuer-name> s= " (" "issuer" " (" "name" <principal> <byte- 

string> " ) " " ) " ; 

<low-lim> = <gte> <byte-string> ; 

<lte> a "1" | "le" ; 

<name> = <relative-name> | <full-name> ; 
<name-cert> = "{" "cert" <version>? <cert-display>? 

< issuer- name > < issuer- info? 

<subject> <subject-inf o>? 

<valid> <comment>? "}" ; 
<not~after> = "(" "not-after" <date> ; 
<not-before> = "{" "not -before" <date> ")" / 
<n-val> - <byte-string> ; 

<object-hash> = "(" "object-hash" <hash> ")" ; 
<one-valid> - "(" "one-time" <byte-string> ; 
<online-test> = "{" "online" <online-type> <uris>? <principal> 
<s-part>* ")" ; 
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<online-type> - "crl" | "reval " | "one-time" ; 
<principal> = <public-key> | <hash-o£-key> ; 
<proof> = {<cert> ) <name-cert>) * 

<public~key> = "{" "public-key" <pub-sig-alg-id> <s-expr>* 
<uris>? " ) " ; 

<pub-sig-alg-id>= "rsa-pkcsl-md5" | "rsa-pkcsl-shal" | "rsa- 
pkcsl" | "dsa-shal" | <uri> ; 

<range-ordering>= "alpha" | "numeric" | "time" | "binary" | 
"date" ; 

< relative- name > = " {" "name" <byte-string>+ " ) " ; 
<requires> = "(" "requires" <tag>* ")" ; 
<restrict-date> ~ "date" <date-expr> " ) " ; 

<restriction> = <restrict-date> | <target> | <requires> ; 
<restrictions> - <restriction>* ; 

<reval> = " (" "reval" <version>? <subj-hash> <reval-body> ")" ; 
<reval-body> = <one-valid> | <valid-basic> ; 

<signature> = " { " "signature" <hash> <principal> <sig-val> ")" ; 
<sig-val> = <s-part> ; 

<subject> = "(" "subject" <subj-obj> ")" ; 
<subject-info> = " (" "subject-info" <uris> ; 
<subj-hash> ~ "(" "cert" <hash> ")" ; 
<subj-obj> = <principal> | <name> | <object-hash>; 
<tag> - "(" "tag" <tag-expr>* «)» ; 
<tag-and> = "(" "*" "and" <tag-expr>+ ")■' ; 
<tag-expr> = <byte-string> | <tag-simple> 

| <tag-prefix> | <tag-range> 

I <tag-set> | <tag-and> 

| <tag-star> ; 
<tag-simple> = "(" <byte-string> <tag-expr>* ")" ; 
<tag-prefix> = "*" "prefix" <byte-string> ,* 

< tag- range > = "(" " *" "range" < range- order ing> 
<low-lim>? <up-lim>? "}" ; 

<tag-set> = "(" "* B "set" <tag-expr>* »)" ; 

<tag-star> = " ( " "*" ")" ; 

<target> = "{" "target" <tag-expr>* ")" 

<up-lim> = <lte> <byte-string> ; 

<uri> = <byte-string> ; 

<uris> = ,l uri" <uri>* ")" ; 

<valid> = <valid-basic> <online- test>* <restrictions> ; 
<valid-basic> = <not-bef ore>? <not-after>? ; 
<version> = "(" "version" <byte-string> " )" ; 

The elements <reval>, <online-test> (and related elements such as crl) and 
<restrictions> are parsed but silently ignored in the current implementation. 
Architectural extensions will be introduced to support these elements. 
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Overview 

The only way for a Client to request access to a Resource from a Resource Handler 
is to send a message through the e-speak core. The only way for a Resource Handler 
to return a reply to a Client is to send a message through the e-speak core. Thus, the 
core mediates all access between Clients and Resource Handlers. It is the only 
entity to accept connections: Clients and Resource Handlers establish connections 
to an e-speak Core so that they can communicate with each other. 

All messages handled by e-speak cores are Protocol Data Units (PDU s), described 
below. 

The possible exchanges of messages follow the Session Layer Security protocol 
"Session Layer Security Protocol (SLS)" on page 132. 

Mediation by the e-speak core may include: 

• Determining to which Inbox to route the message. 

• Determining how to route the message (its routing path). 

• Processing and transforming the message headers and contents. Only 
limited processing of the message is possible if security is enabled, 
implying that a Message Authentication Code (MAC) is appended. If so, 
fields of the PDU header which have been used to form the MAC must not 
be changed "Authentication of messages" on page 144. 

Mediation is transparent to the Client and Resource Handler. 
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The e-speak core keeps no state information about messages beyond the time 
needed to complete processing. It does not keep any information about replies to 
messages. As far as the core is concerned, a reply is another message. It doesn't 
distinguish between clients and resource handlers: an entity which sends it a 
message is a u client" so far as it is concerned, and the destination is simply an Inbox. 

If a Client needs a reply, it may wait or send another message; all messaging is 
asynchronous. Each asynchronous message has an identifier set by the sender. A 
reply can refer to this identifier so the Client knows to which message the reply has 
been sent. 

Figure 6 shows the flow of messages through an e-speak core when a Client sends 
and receives messages from a Resource Handler. 
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Figure 6 Message flow with an e-speak core 
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A client is not restricted to resources connected to the same e-speak core as itself. 
Figure 7 shows the message flow when a Client sends and receives messages from 
a Resource Handler on a remote e-speak core. The same protocol is used to 
exchange messages between e-speak cores as is used to exchange messages 
between Clients and e-speak Cores. 




OB = Outbox 
IB « Inbox 

Figure 7 Core-to-core message flow 

The creation and management of core-to-core communications is decribed below 
(see "Core to core communication" on page 151), 
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All messages exchanged between e-speak cores, and between e-speak cores and 
clients are PDUs. A single PDU corresponds to a single Session Layer Security (SLS) 
Message. 

A class hierarchy for PDUs is shown in Figure 8. The members PDU.data, 
HandShake.data and MessageForResource.payload are all byte-arrays which in 
principle could hold an object of any class. Which class-instances are present in a 
PDU is given by the values of: 

• PDU.messageType - for the contents of PDU.data 

• HandShake.type - for the contents of HandShake.data, if present. 

• MessageForResource.payloadType - for the contents of 
MessageForResource.payload, if present 

The permissible values of PDU.messageType and the corresponding contents of 
PDU.data are: 



ALERT (0) 
HANDSHAKE (1) 
APPLICATION_MESSAGE (2) 
TUNNEL (3) 
PING (4) 



MessageForResource 
(Tunneling) PDU 
Ping 



Alert 



HandShake 
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Figure 8 PDU class hierarchy 



PDU 

versionMajor 

versionMinor 

spi 

spiSender 
serai 

inReplyTo 

mesiageType 

encoduigType 

toAddres* 

fromAddress 

route 

data 



level 
code 
detail 

-HandShake 
type 

data— - 



- MessageForRescfurce 
versionMajor 
versionMinor 
tag? 

ABIVersion 

payloadType 

isVoid 

payload 



- HandShakeRequest 
. HandShakeStart 

HandSnakeRaply 

- HandShakeFinish 



-Tunneling PDU 



metnodCall 
methodResult 

(unspecified) 



exceptionResponse 
- eventMessage 



Ping 



ID 
type 



Developer Release X. 03.03.00, September 2000 



119 



Protocol Data Unit (PDU) 



Communication 



The class PDU is: 

class PDU { 
int versionMajor; 
int versionMinor; 
int spi; 
int spiSender; 
int serial; 
int inReplyTo; 
int messageType; 
int encodingType ; 
String toAddress; 
String fromAddress; 
byte[] route; 
byte [ ] data; 

} 

Version no.s 

The current value for versionMajor is 1, and for versionMinor is 0. 
SPI members 

SPI stands for Session Parameter Index. This is used by the two endpoints in the 
Session Layer Security protocol to indicate which session the message is being sent 
on. Since the sender and the receiver may identify the SPI separately we have two 
fields: spi denotes the recipient s SPI; spiSender denotes the sender's SPI. 

Message serial no. fields 

Two fields are used by SLS to protect against replay attacks: serial is set by the 
sender; inReply to is the serial field of the message to which the sender is 
responding. 

Message types 

The following values for message type are defined: alert (0), handshake (1), 
application message(2), tunnel (3), ping (4). Alert, handshake, tunnel and ping are 
used in SLS to manage sessions * Session Layer Security Protocol (SLS)" on 
page 132. These types are described in the following section. 
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Encoding types 

The following encoding types are defined for a PDU: clear data ( 0); protected 
data(l); secure data (2). Protected data is authenticated and protected from 
tampering by a Message Authentication Code (MAC) [see Schneierpp. 455-459[. 
Secure data is protected by a MAC and also encrypted for confidentiality. 

Addresses 

The String toAddress is an absolute ESName [see ESNames section below] and 
denotes the destination for the message. The String fromAddress is also an absolute 
ESName. It denotes the sender of the message and can be used for replies. The e- 
speak core attempts to resolve these names in its Root name-frame by finding the 
Mapping Object (see Chapter 4, "Core-Managed Resources") associated with each 
ESName. The Mapping Object is used by the e-speak core to refer to a Resource, a 
Search Recipe, or any combination. 

If the e-speak core cannot unambiguously identify the Resource Handler for the 
toAddress, it will send an exception message to the Client The format for an 
exception message is described in Chapter 7, "Exceptions". The possible 
exceptions are shown in Table 7 on page 131. 

Route member 

The byte-array route can be used by applications to pass routing data. This is never 
encrypted or protected by a MAC. 

Data member 

The format of this byte-array is determined by the encoding type. If the encoding is 
clear data, the byte array is a message body, of contents indicated by the message 
type. 

If the encoding is secure data, then it has been encrypted according to the cipher 
negotiated in the SLS session set-up. Once it has been decrypted, it will have the 
same format as protected data: a MAC, followed by the message body. The contents 
of the message body is indicated by the message type. It will be an object of one of 
the classes described below. 

These elements of a PDU are marshalled in the order of member definition shown 
in the class declaration above. 
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Marshalling of PDU Elements 

In general, PDU's are marshalled according to the PDU marshalling format (PDFM) 
described below (see TDU Marshalling format" on page 170). This applies to the 
PDU class listed above. However, for application messages the e-speak serialization 
format (ESF) (see "E-speak Serialization Format" on page 170) is used in principle. 
Currently this is not compatible with SPKI certificate formats (see Chapter 5, 
"Access Control*), so some messages are serialized partly using PDFM and partly 
using ESF. Where this happens we label each field either (PDFM) or (ESF). 
Otherwise we label the class corresponding to the message type. 

Top Level PDU Message types 

The data member of a PDU will contain an instance of one of the following classes, 
depending on PDU.messageType, as explained above. The elements of each 
message are marshalled in the order in which they appear in the class definition. 

Alert 

Class Alert { (PDFM) 
byte level; 
byte code; 
String detail; 

} 

The Alert message is used for SLS session management. Valid level values are: 

fatal (0x00) 
warning (0x01) 
debug (0x02) . 

All codes are normally sent with a level of fatal, unless indicated. Valid codes are: 

• CLOSE_NOTIFY (0x00) (warning) 

• UNEXPECTED_MESSAGE (0x01) 

• BAD.SPI (OxOA) 

• BAD.SERIAL (OxOB) 

• BAD.MAC (OxOC) 



122 



Developer Release X.03.03.00, September 2000 



Communication 



Protocol Data Unit (PDU) 



• HANDSHAKE_FAILURE (0x14) 

• BAD.CERTIFICATE (0x15) 

• UNSUPPORTEDCERTIFICATE (0x16) 

• CERTIFICATE.REVOKED (0x17) 

• CERTIFICATE_VERIFICATION_FAILED (0x18) 

• ILLEGAL_PARAMETER (0xlE)= 30; 

• BAD_PROTOCOL_VERSION (OxlF) 

• INSUFFICIENT.SECURITY (0x20); 

;=j . NO_RENEGOTIATION(0x28) (warning) 

^1 • ERROR (0x32) 

jli The detail String is intended for human consumption and is left unspecified. 

i|! 

ii| Default and Implicit Session Alerts 

^ These are newly introduced, to handle the following situations: 

y, . A request is made on the default Session (SPI = 0, no security) , but the recipient 

f|| requires a secure Session. The recipient sends back an alert with the code 

i jj INSUFFICIENT.SECURITY, and the requestor can establish a secure Session in 

ij! response. 

2J • A request is made on a secure Session, to a Resource that previously 

communicated on that Session, but that Session has died (due to disconnection 
or other causes) at the recipient's end. The recipient sends an alert with the code 
BAD_SPI. The requestor removes that Session (which it previously had stored 
under the URL of the Resource) and may negotiate a new Session. 

Handshake 

class Handshake { (PDFM) 
int type; 
byte data [] ; 

} 
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The possible values of Handshake.type and the corresponding contents of 
HandShake.data are described below (see "Handshake message types" on page 125) 

Application message 

When APPLICATION.MESSAGE is the message type, the data field of the PDU 
contains an instance of MessageForResource. 

class MessageForResource { (PDFM) 
byte versionMajor; 
byte versionMinor; 
ADRList tags; 

short secondaryABIVersion ; 
byte payloadType; 
boolean isVoid; 

byte payload []; (ESF this field only) 
) 

The current value of versionMajor is 2 and of versionMinor is 0. These are 
different from the members with the same names in the PDU class. 

ADRList is a list of SPKI tags using the *-set form as defined in tt SPKI BNF Formats" 
(Chapter 5, "Access Control" ) 

secondaryABIVersion currently has the value 0. It specifies the format of the data 
field when communicating with core-managed resources. 

isVoid indicates whether or not there is a payload. If isVoid is true, there is no 
payload and it is not marshalled or unmarshalled. 

payloadType and the corresponding class-instances held in payload are described 
below (see "Payload Message Types" on page 128). 

Tunnel 

If the message type of PDU isTUNNEL, the data field of the PDU contains another 
PDU. The outer PDU is removed. The PDU contained in the data field is 
unmarshalled and forwarded to the address contained in the toAddress field of the 
inner PDU. The contents of the inner PDU, except for the toAddress field, may be 
encrypted - the object is to pass encrypted messages across a firewall. 
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Ping 

class ping{ (PDFM) 
String ID; 
byte type; 

} 

Ping messages are used by SLS for session management. 
The current value of ID is H SLS:Ping:vl.O\ 
Two values of type are defined: 

• Request (0x00) 

• Reply (0x01) 

Handshake message types 

The value of HandShake.type indicates the contents of HandShake.data, as follows: 
TYPE VALUE CLASS-INSTANCE IN DATA 

HANDSHAKE.REQUEST (0) HandShakeRequest 
HANDSHAKE_START (1) HandShakeStart 
HANDSHAKE_REPLY (2) HandShakeReply 
HANDSHAKE.FINISH (3) HandShakeFinish 
In all the classes, listed below: 

• The current value of the ID member is "SLS:HandshakeStart:vl .0". 

• The current values of majorVersion and minorVersion, if present, are 
0x01 and 0x00 respectively. They indicate the highest version of SLS 
supported by the sender. 

Handshake request 

class HandShakeRequest { (PDFM) 
String ID; 
boolean flag; 
PDU pdu; 

} 
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Handshake request is used to request a renegotiation of the session parameters. 

The boolean flag is set to true if the request includes a PDU, otherwise no PDU is 
included. The PDU is intended to be used for synchronization: it would contain the 
last message between the two parties. Currently it is not used. 

Handshake start 

class HandShakeStart { (PDFM) 

String ID; 

byte majorVersion; 

byte minorVersiori; 

int spi; 

ADR group; 

ADR keyData; 

ADR cipherSuiteList; 

ADR tags; 

ADR query; 

} 

The type ADR (ASCII Data Representation) is an s-expression as defined in Chapter 
5, "Access Control" - "SPKI BNF Formats" . All the Handshake classes have ADR 
members. 

spi is the session parameter index of the sender of this message. 

group is the definition of the Diffie-Hellman group. 

keyData is the sender s part of the Diffie-Hellman key-exchange. 

cipherSuiteList is the list of valid cipher suites in decreasing order of preference. 

tags is the list of SPKI tags the sender is requiring the receiver to prove. 

query is the sender's query on the recipient. The sender can use this field to declare 
the operations it wishes to invoke within the session once it is established. This can 
be used by the recipient to determine what tags it will require the sender to prove. 

Handshake Reply 

class HandshakeReply{ (PDFM) 

String id; 

byte major-version; 

byte tninorversion; 

int spi; 

adr keydata; 
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adr ciphersuite; 

adr proof; 

adr tags ; 

boolean relay; 

S t r i ng f or war daddr e s s ; 

adr signature; 

} 

spi is the Session Parameter Index of the sender. 

keydata is the sender's part of the DifFie-Heliman key exchange. 

ciphersuite is the sender s chosen cipher suite selected from the list of cipher 
suites in the initial HandshakeStart message. 

proof is the list of certificates that will prove the tags that the sender of the 
HandshakeStart message required. 

tags is the list of tags the sender is requiring the receiver to prove. This may have 
been generated by having examined the query member in the intial HandshakeStart 
message. 

relay is set to true if the responder will relay subsequent messages to the addressee: 
a tunnel is to be set up. If relay is true, the responder will not have to produce 
certificates authorizing the tags requested in the HandshakeStart message. 

If relay is set to true, forwardAddress will contain the absolute ESName of the 
recipient to which this message is to be forwarded. 

signature is the signature of the hash of this message and the initial 
HandShakeStart message. 

Handshake finish 

class HandshakeFinish{ (PDFM) 
String id; 
adr proof; 
adr signature; 

} 

proof is the list of certificates that will prove the tags that the HandshakeReply 
message requires (in that message's tags member). 

signature is the signature of the hash of this message, the previous 
HandshakeReply and the HandshakeRequest message. 
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The value of MessageForResource.payloadType indicates the contents of payload 
as follows: 



PAYLQADTYPE VALUE 

METHODJCALL (0) 
METHOD_RE SULT { 1 ) 
EXCEPTION (2) 
EVENT (3) 
OBJECT (4) 



CLA SS-INSTANCE IN PAYLO AD 

methodCall 
methodResult 
except ionRe spons e 
eventMessage 
(unspecified) 



The payload field contains the message for the resource. 

The payload format is not specified if the payload type is set to OBJECT. This is for 
use by applications to communicate with external resources. The Resource Handler 
can specify any format it chooses. 

Payload of messages to Core-Managed Resources 

A PDU sent to a core-managed resource has the payload type METHOD_CALL, and 
the payload member contains a methodCall object: 

public class methodCall (ESF) 

{ 

String interf aceName ; 
String methodName 
Ob[] arguments; 

} 

The first two fields define the interface and method to be invoked. The type "Ob w 
stands for any object that can be marshalled in ESF. 

Initial Connection Request 

A client s initial request for connection is an example of a PDU with a payload as 
above.. The fields are set as follows: 

interf aceName = "core" 
methodName = w boot strap" 
arguments - null 



128 



Developer Release X. 03. 03. 00, September 2000 



Communication 



Protocol Data Unit (PDU) 



Routing to External Resources 

A message to an external resource is also sent as a PDU to the e-speak core, but with 
the payloadType OBJECT and a payload unspecified by e-speak. The e-speak core 
will route this message to the resource handler if it can. 

It cannot do so if the " To* field of the message is not a valid Resource, or if the Inbox 
specified in the destination Resource metadata is not connected to a Resource 
Handler, or if the Resource Handler s Inbox is full. 

When it cannot deliver the message, the e-speak core will return an error 
(exception) message to the Client, if it can. If the Client's Inbox can't take the error 
message for any reason, the e-speak core discards the message. 

Normally, the e-speak core places the following data in the route field of the PDU: 

class routeData{ 
String slot; (PDFM) 

boolean specif icationNonNull ; (PDFM) 

ESmap privateRSD; (ESF) 

ADR mask; (PDFM) 

ADR service ID; (PDFM) 

} 

The slot field is used to enable many Inboxes to share a single channel (TCP 
connection in the current implementation). The slot identifies which Inbox the 
message is for. 

If specificationNonNull is set to false, the three fields following are not marshalled. 
These three fields are parts of the resource s metadata held by the e-speak core. 
The privateRSD field is the resource s private RSD. 

The mask field tells the resource handler which methods have security disabled. 

The servicelD field is the service identity for the resource. Both these fields are 
<tag-expr> as defined in Chapter 5, "Access Control" - *SPKI BNF Formats*. 
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Payload of messages from Core-Managed Resources 
Initial Connection to the Core 

The e-speak Core listens on a TCP port for Client connections (the default port is 
12345). When it receives a connection request (see "Initial Connection Request" on 
page 128) a TCP channel is created between the Client and the Core. The Core 
creates a default protection domain for the Client and sends a PDU back to the 
Client, of type MessageForResource, with payloadType set to METHOD_RESULT. 
The methodResult in the payload will contain a bootstrapReply object: 

class bootstrapReply { (ESF) 

ESname Inbox; 

String InboxSlot; 

ESname CallbackResource; 

ESname Except ionHandlerRe source ; 

String anchor; 

} 

Inbox and InboxSlot are the ESnames of the inbox and the slot allocated by the 
e-speak core to the client. The CallbackResource field is the ESname to be used 
to send messages to the client This should be used in the fromAddress field of 
PDU's sent by the client. 

The ExceptionHandlerResource is deprecated and should not be used. 

The anchor field is the URL of the root name-frame of the Protection Domain 
which has been created by the e-speak core for the client. 

Normal reply 

A PDU sent from a Core-managed Resource, in reply to a methodCall when no 
exception has been thrown, has the payload type METHOD.RESULT, and the 
payload member contains a methodResult object: 

public class methodResult 

{ 

Ob result; (ESF} 

} 

The bootstrapReply sent in reponse to a connection request is a special case of 
methodResult. 
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Exceptions 

When an exception is thrown the payloadType is EXCEPTION and the payload 
member of messageFor|Resource is an instance of exceptionResponse: 

public class exceptionResponse { 

Ob result; (ESF) 

} 

One of the following exceptions will be thrown when the e-speak core cannot 
unambiguously identify the Resource Handler for a given toaddress: 



Table 7 Exceptions for unresolved Resource Handler 



Exception 


Description 


NameNotFound Exception 


The lookup procedure failed to find a 
Mapping Object 


UnresolvedBindingException 


The only accessors in the Mapping Object 
are Search Recipes. 


MuitipleResolvedBindingException 


The explicit bindings in the accessors refer 
to Resources with different Resource 
Handlers. 


UndeliverabieRequestException 


The Resource Handler does not have the 
Resources needed to receive this message, 
or the Handier Inbox is not currently 
connected. 



Events 

When the core generates an event it will send a PDU with the data field containing 
a messageForResource, which will have the payloadType set to EVENT. The 
payload will be an eventMessage. 

public class eventMessage 

{ 

Ob result; (ESF) 
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Messages from a Resource Handler to a Client 

E-Speak implements a peer-to-peer communications model for messaging. 

The Core does not distinguish between a message sent from a Client to a Resource 
Handler and a reply from the Resource Handler back to the Client. The Resource 
Handler sending a reply to a Callback Resource is treated as the Client, and the 
Client receiving the reply is treated as the Resource Handler for the Callback 
Resource. 

Clients may have more than one Inbox. The only way for a Client to receive a 
message from any other Client is to register a Resource listing one of its Inboxes in 
the Resource Handler field of the metadata. Clients can manage different classes of 
messages by registering different Resources designating different Inboxes. Clients 
can also deal with different message classes by associating certain classes with 
Events. 



Session Layer Security Protocol (SLS) 

The Session Layer Security (SLS) Protocol determines all possible exchanges of 
PDU messages between clients, e-speak cores and resource handlers. The protocol, 
used between a client and a resource handler, may establish a secure session 
between them. It can also be used to establish an open, non-secure session. All SLS 
communication is carried in PDU messages, and all PDU messages are sent under 
the SLS protocol. 

A secure session has the following properties. 

• All messages exchanged between the two end points are authenticated. This 
prevents messages being changed or messages being inserted into the TCP 
connection by a third party (e.g. an attacker). 

* All message exchanged between the two end points are protected against replay. 
This prevents a third party capturing the messaging and replaying it at a later 
date to trigger a repeat of the action taken by the recipient. 
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Messages exchanged in a secure session may be encrypted for confidentiality. This 
prevents a third party from reading the contents of a message. 

In a non-secure session messages are exchanged without encryption, 
authentication or protection against replay. 

The SLS (Session Layer Security) protocol extends the capabilities of SSL [see RFC 
2246[ , a protocol that is supported by most modem web browsers, and is currently 
the default way to secure client/server interactions over the web. The motives for 
departing from SSL are: 

• Transport independence: SSL links a security session with a TCP socket. If the 
socket dies the security session dies with it: something undesirable when the life 
expectation of a security session is very different from the life expectation of the 
transport. Also, we cannot multiplex several security sessions onto the same 
socket, or perform dynamic load balancing of the end-point without starting the 
session from scratch. Moreover, even though properties like reliability and in- 
order delivery of messages are critical for a security protocol some TCP details 
are not, and this might put unnecessary restrictions on the applicability of SSL. 
Finally, in some cases we might want to use a different transport for sending and 
receiving messages (i.e., outgoing messages use a different firewall needing two 
sockets). SLS tries to make the minimum number of assumptions on the 
communication transport solving most of the issues above. 

• Tunnelling support: During firewall traversal we might want the firewall to 
control the client access rights to the internal LAN for every packet. However, 
we might not want the firewall to see all the traffic in clear (therefore, losing the 
end-to-end security property). This is difficult to achieve with SSL because 
either we let the client open a direct socket to the service or the firewall will see 
all the traffic in clear. On the other hand, with SLS we can nest a secure session 
inside another one, possibly with different end points, allowing to achieve both 
goals simultaneously, 

• Elliptic cryptography: Most implementations of SSL only support Diffie-Hellman 
key agreement algorithms based on exponentiation. SLS uses a faster algorithm 
based on Elliptic Curve Cryptography (ECC) described by [Seroussi and 
Smart 
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• Attribute certificates using SPKI [see RFC 2692 - 2693\ . SSL only supports X509 
name certificates, mainly to authenticate that the end-point "owns" , according 
to a configured " trusted CA* , the web address that we wanted to reach. Only one 
certificate by each party can be used, and in most cases only server 
authentication is performed. On the other hand, SLS performs a negotiation of 
tags that need to be proven represented by multiple SPKI certificates. This 
allows a fine grained control of security by mapping tags to actual permissions, 
raising the level of abstraction from "a stream of bytes" in SSL to a particular 
operation on service X in SLS, making it easier to integrate with application level 
security. Details on the use of SPKI certificates in SLS can be found in Chapter 
5, * Access Control\ 

• Latency minimization: SLS allows the client to send application data after a 
round-trip negotiation has succeeded. In SSL two round-trips are needed before 
the application data is sent. This can have important performance implications 
when network delays are large and we need a quick response from the server. 

Functional Description of SLS 

In this section we describe the expected behavior of the protocol. 
Protocol message types 

Every SLS message is embedded in a PDU (Protocol Data Unit) (see "Protocol Data 
Unit (PDU) 11 on page 118), which contains header information allowing the system 
to dispatch it to the correct security context, route it through the network, identify 
replies, ensure the protocol version and so on.Two fields of this header relevant to 
our discussion classify messages according to the type of encoding and their 
purpose: 

Supported encoding types 

• CLEARED AT A: The message is not encrypted or protected against modification. 

• PROTECTEDJDATA: The message is not encrypted but it is protected against 
modification with a signed digest (MAC) 

• SECURE_DATA: The message is encrypted and protected against modification 
using a MAC. 
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Supported message types 

• HANDSHAKE: Message exchanged during the key-agreement protocol. There 
are four types of handshake messages that will be discussed later. 

• ALERT: Message that identifies an abnormal situation during the handshake or 
after the session has been established. ALERT messages can be fatal, forcing 
session termination, or just warnings, for which the response is implementation 
dependent 

• APPLICATION_MESSAGE: Message that communicates application data, 

• TUNNEL: A message that contains another PDU in its payload. This is used to 
nest sessions, something important for firewall traversal. 

• PING: A heartbeat message that is used by the session scavenger to know if the 
session is still active. 

• REKEY: Forces a key offset of the instantiated cipher suite based on the 
previously negotiated shared secret. (REKEY is not supported in the current 
implementation.) 

High level protocol state machine 

Figure 9 High level state transitions in SLS. 




Figure 9 shows the possible states of a session, and what triggers transitions 
between them. There are four possible states: 

• START: the session object has been created but it is not fully configured. Also, 
the key agreement protocol has not started. 
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• SETJJP: the key agreement protocol has started. We do not have a shared secret 
yet, so all the messages have CLEAR_DATA encoding. It depends on the 
implementation whether any response is made to unauthenticated ALERT 
messages. 

• READY: the key agreement protocol has successfully completed. We have a 
working session that we can use to encrypt/decrypt messages and validate 
whether the session has certain security tags associated with it. At this point 
ALERT messages are authenticated and should not be ignored. 

• DEAD: the session is no longer operational and will never be. We can safely 
scavenge it. 

Also, we can see in Figure 9 the events that trigger state transitions: 

• init: complete the initialization of the session object and send a message to the 
other party (if needed) to start the key agreement. 

• sessionOK: The key agreement has finished successfully and we have a new 
cipher suite to install in the session. 

• timeout: a timeout expired. The different timeouts are explained in detail below 
(see "Timeouts description" on page 146). 

• alert: an authenticated (or optionally non-authenticated) fatal alert was handled/ 
sent forcing a shutdown of the session. 

• close: a client forced termination of a session by invoking the close 0 method. 
Two important operations on a session are handling and sending a PDU. 

SLS Handling a PDU 

The handling operation assumes that the PDU has already been received from the 
transport and invokes some security processing on the PDU (i.e M decryption/ 
authentication). 

Depending on the state of the session, and the encoding/type of the PDU, the 
session behaves differently while handling PDUs. Table 8 on page 138 shows the 
expected behavior of a session when handling a PDU. 

The terms in that table have these meanings: 
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MAC: either PROTECTED_DATA or SECURE_DATA encoding type. Obviously, 
the important property is that the PDU is correctly authenticated, otherwise we 
will always ignore the message regardless of its claims. 

Exception: notify the client doing the handling that the session is not 
operational 

Ignore: do not take any significant action based on that PDU (i.e., change session 
internal state). Optionally, an implementation could log the event that a PDU is 
being ignored. 

Optional: an action is considered optional if an implementation can decide to 
ignore the PDU instead. 

Warning: send a warning ALERT response to the other party. 

HandleHsh: handle a HANDSHAKE PDU by making progress in the key 
agreement protocol. This could involve an Internal Send of a HANDSHAKE or 
ALERT PDU to the other party. 

HandleAl: handle an ALERT PDU. This might involve closing the session if it is 
a fatal alert, or logging the event otherwise 

HandleApp: handle an APPLICATION.MESSAGE PDU. Typically, the PDU will 
be passed in clear text to the client if it authenticates and/or decrypts correctly; 
otherwise it is ignored. 

HandleTun: handle a TUNNEL PDU. This could involve "peeling off the outer 
PDU, returning the inner one (after decryption/authentication of the outer one) 
or calling a custom handler to deal with it. 

HandlePin: handle a PING PDU. This handling might require sending a reply 
PING PDU or just record that our previous PING has been replied successfully. 

HandleRe: handle a REKEY PDU. Forces the re-key of the handler part of the 
crypto suite. 
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Table 8 PDU handling behaviour depending on state 
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SLS Sending a PDU 

The sending operation will first invoke the required security processing (i.e, 
encoding, MAC computation) and then it will use the underlying transport to deliver 
the message at the other end. Note that handling a PDU might have as a side effect 
that another PDU is sent to the other party, i.e., a response to a handshake message 
during the key agreement. We call that case an internal send as opposed to an 
external send directly invoked by the client 
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Table 9 shows the expected behavior when trying to send a PDU through a session. 
Table 9 PDU sending behavior depending on state 
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Some terms in that table deserve further explanation: 

• NotApply: it is an implementation error if the protocol tries to send this message. 
This is only relevant for internal messages: the implementation does not have 
control over possible external messages. 

• OK: this means that the session will perform the appropriate processing and try 
to deliver it to the lower layer. This does not mean that the message has been 
correctly sent, because this depends on the status of the underlying transport/ 
session. 
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• Retry: The client is informed that the session is currently unavailable to send 
messages but this might change in the future. 

• Exception: The client is informed that the session is permanently unavailable. 

The key-exchange protocol 

The key-exchange protocol is an authenticated Diffie-Hellman key exchange. From 
the session key agreed in the Diffie-Hellman exchange further keys are derived for 
encryption and confidentiality. 

Features of the exchange are: 

• Elliptic Diffie-Hellman key exchange instead of modulus exponentiation. 
Instead of choosing a group and checking its validity at the other end, we pick 
one of a pre-determined family of elliptic curves [see Seroussi & Smari\. Each 
party uses a random point on the curve as a private key, generates a second point 
from the first to send as a public key, and checks that the point he receives 
belongs to the same curve, 

• There is no current support for multiple public keys of the same principal. This 
extension should be trivial by adding more than one signature in the handshake. 

• Added tunneling support: we allow the responder to notify in its first handshake 
message that it wants to relay the session. Tunneling is described below (see 
"Support for tunneling" on page 149) . When tunneling is indicated, the responder 
might not have to prove the tags requested. 

• Randomized Session Parameter Indices (SPIs). We want SPIs to be hard to 
guess, to avert denial-of-service attacks. If SPI's are predictable, it is too easy to 
flood the client/server with fatal alert messages. At the same time, we want to be 
able to pay attention to non-authenticated alerts during the handshake (handling 
alerts is described in (see "Handling alert messages" on page 145)). 
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Figure 10 Key agreement protocol 



Initiator 



Responder 




Figure 10 shows the key agreement interactions and corresponding state machines 
of the handlers that control these interactions. These state machines are embedded 
in the state SETJJP in Figure 9. Sub-states READY and DEAD are not necessarily 
related to the ones in Figure 9. For example, killing the handler does not mean that 
the session will die. It is perfectly normal that the handler will terminate when the 
key agreement finishes successfully, and the cipher suite gets "instantiated" in the 
session. 

A quick summary of the messages sent during the handshake: 

• HskRequest: a request from either party to re-negotiate a session 

• HskStart: a request (or acknowledgement) from the client to the server to start 
a session. It contains the elliptic curve and cipher suite list suggested, the SPI at 
this end, a hint on the tags that the server should prove, a hint on the operations 
that we want to perform, and a public Diffie-Hellman (DH) key. 

• HskReply: a reply to the previous HskStart from the server to the client. It 
contains the cipher suite chosen, the SPI at the server end, whether the server is 
a relay, certificates to prove the requested tags, a hint of tags that the client need 
to prove, a public DH key and a signature. 



Developer Release X.03.03.00, September 2000 



141 



Session Layer Security Protocol (SLS) 



Communication 



• HskFinish: last Handshake message from client to server. It contains certificates 
to prove the requested tags and a signature. 

• Alert: notify the other end of a failure of the key agreement. 

We made the Initiator and Responder state machines similar by always introducing 
a HskStart message. If the protocol is started by the Initiator the HskStart is 
generated locally. Otherwise it will be generated by the Responder and transmitted 
through the network. We pay attention to alerts and "incorrect* messages that have 
valid random SPI, so we can end the session at any time during HandShake. 

The protection layer 

This term is used for the set of instances of encryption/decryption, hashing and 
authentication algorithms, along with the particular key-values, to be employed in 
a session. The protection layer is established through the HandShake phase. 

Elliptic Curve Cryptography is used for the initial Diffie-Hellman shared secret 
negotiation instead of modulus exponentiation. The handshake has established an 
elliptic curve (in an integer space) and each party has chosen a point at random on 
this curve, which he keeps entirely secret. Call these two points U and V. They are 
private keys. A function f generates two other points f (U) and f (V) , on the same 
curve. These are public keys, and are exchanged. (Inverting f, to find the argument 
from the function value, is not believed to be practicable for our current choices of 
curve and of f.) The two parties both check that the points they receive are valid 
points on the curve. There is a function g such that: 

g[u, f(v)] = g[v, f (U)] - z 

This is the shared secret, which is used to generate the authentication and 
decryption keys as described below. 
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Key generation algorithm 

For details of key-generation see [Ferguson, Section 4.]. Four fixed byte-arrays are 
used as follows: 

array A - for the key K A that authenticates client to server 
array B - for the key K B that authenticates server to client 
array C - for the key K c that encrypts client's messages to 
server 

array D - for the key K D that encrypts server's messages to 
client . 

The keys are symmetric, so is used to decrypt messages from the client, as well 
as to encrypt them; likewise K$ for messages from the server. K A is used both to 
create and to verify the client's HMAC's, and K B for the server's. 

The keys are derived from the byte-arrays as follows. The shared secret Z (or a 
function of it) is expressed in a fixed byte-array. This is appended to each of arrays 
A to D, giving byte-arrays which we will call Key_array A, B etc. For example, 
Key_array A = array A | Z. 

The hash function h is applied recursively to each Key_array. From the Key_array 
s, byte-arrays s 0 , s 1? s k are created, obeying: 

s 0 - h(s) 

s n - h(s 0 | s x | ... Is^il s) (n >= 1) 

Repeated recursion generates longer and longer byte-arrays as the argument to h. 
There are two target lengths: L A for the authentication keys K A and K B , and L E for 
the encryption keys and K^, determined by the corresponding algorithms. For 
each key t recursion proceeds till the length of s 0 |s 1 |...js k equals or exceeds the target 
length. The first L A or elements make up the key. 



Cipher suite support 

The encryption algorithms currently supported are Blowfish with a 128 bit key, and 
triple DES with three independent keys for encryption. Blowfish is the 
recommended cipher because of its speed but 3DES is the conservative choice. Also 
only CBC mode and PKCS 5 padding is supported. 
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Our current hash algorithm is SHA-1 and our MAC algorithm is an HMAC 
construction based on SHA-1. 

SPKI certificates are signed/verified using ElGamal with a 768-bit key as default. 
RSA with a 1024 bit key can be used if the client prefers. (All the named algorithms 
are explained in [Schneiei\) 

Authentication of messages 

See [Menezes, van Oorschotand Vanstone p.355] and [Ferguson, Section 4.] 

A hash is generated from the appropriate authentication key (K A or K B above), 
selected fields of the PDU header, and the PDU body. This is the MAC: it has a fixed 
length (of 20 bytes in our implementation). It is pre-fixed to the PDU body. If the 
encoding type is SECURE_DATA, the resulting string (MAC + PDU body ) is 
encrypted using Kq or Kp. The resulting encrypted string we call Q.The PDU 
transmitted will consist of: 

• PDU header 

• PDU body + MAC if type is PROTECTED_DATA 

• Encrypted string Q if type is SECUREJDATA 

For the recipient to check the message, if the type is SECUREJDATA, it begins by 
decrypting Q, using K c or K D as before. This gives a string: MAC + PDU body. The 
selected header fields, the PDU body (without the MAC) and the authentication key 
K A or Kg are input to the same hash algorithm to generate a second MAC. This is 

compared with the MAC received in the message: if they are unequal the message 
is not authentic. 

The PDU header fields omitted from the MAC derivation are: 
toAddress, fromAddress, route. 
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Handling alert messages 

During the key agreement protocol the default is to pay attention to non- 
authenticated alert messages that have the correct random SPL These identifiers 
are sent in clear, so if the attacker listens to all our traffic and sends fatal alerts with 
the right SPI before the other party responds, it will still stop the session set-up. 
However, this attack would be much easier if we had a predictable SPL The attacker 
could just flood the system with fatal alerts with typical SPIs. In SLS this problem is 
more evident than in SSL, because of the independence of the session from the 
transport. In this case we cannot make the assumption that it takes some effort to 
hi-jack the transport, as is the case for a TCP socket in SSL 

If we want to disable this type of attack completely, we could ignore all non- 
authenticated alerts and rely on timeouts to close failed sessions. This is not the 
default. The convenience of quick and detailed notification of session set-up failure 
is believed to be more important than countering an impractical denial-of-service 
attack. The attack can always be done at transport level anyway. 

In any case, after a session is established only authenticated alerts are respected. At 
that point many messages with the SPIs in clear have been exchanged, and the 
randomization does not help much. 

Alert messages can be fatal, forcing the other end to close the session, or warning, 
that in our first implementation are just logged. We support both internal alerts, 
generated as a side-effect of a PDU handling, and external alerts, those explicitly 
sent by the client. It is recommended however to avoid sending external alerts and 
rely on internal ones as much as possible. The alert codes used in SLS are described 
above (see "Alert" on page 122). 
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Timeouts description 

Figure 1 1 Session timeouts and state transitions 

Tsession(ON) 

Tsetup(OFF) 




There are three built-in timeouts associated with a session: 

• Tsetup: sets the maximum time taken by the key agreement protocol used 
in the SETJJP state. After that time the session becomes DEAD. 

• Tsession; sets the maximum life expectancy of session. This value is the 
minimum of a fixed value (common for all sessions), and the life- 
expectancy of the certificates negotiated during the key agreement. After 
that time the session becomes DEAD. 

• Trekey: sets the maximum time allowed before forcing a rekey operation 
on the session. Rekeying is currently not supported, and Trekey is set to 
infinity. 

Figure 1 1 describes the behavior of the timeouts in relation to the session states. 
Tsetup sets a limit on the time spent on the SETJJP state, but it is reset after a 
transition to the READY state. Tsession limits the maximum time spent on the 
READY state. When Trekey expires we initiate the rekey and reset the timer, but 
this does not imply a state transition. Clearly, Trekey is only useful if it is smaller 
than Tsession, otherwise the session will never re-key. 
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Re-keying (not currently supported) 



Figure 12 Rekey protocol. 
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After the session has been established it is possible to change the key used in the 
cipher and MAC operations by sending a REKEY message. However, this new key 
has to be based on the original shared secret negotiated using Diffie-Hellman (we 
do not re-run the key agreement protocol) . Therefore, the re-key operation does not 
extend the life of the shared secret, only of the derived keys. In particular, the new 
key is obtained by exclusive-or of the first four bytes of the shared secret with a 
random integer before re-running the key generation algorithm. The one-way 
function used in that algorithm ensures that it is difficult to guess the next key, even 
if you know the previous one. The integer xor-ed with the shared secret is 
transmitted inside the REKEY message. 

Figure 12 shows the basic protocol to re-key a session. Node B decides that it wants 
to start a rekey, so it generates a random number (2322) and sends a REKEY 
message with it. After that it re-keys the "send part" of its cipher suite right away, 
so the next message sent will be encrypted with the new key. When the REKEY 
message arrives to node A this node changes its "handle part* of the cipher suite to 
the new derived key. Then it checks that the message is a request and not a reply 
(the rekey was not initiated by him) and sends a REKEY reply message with 
possibly a different random integer (8898), changing the "send part" of its cipher 
suite too. When the reply message arrives to B, this node will update the "handle 
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part" of their cipher suite but it will not rekey the "send part" again because the 
message was tagged as "reply* . 

The important point of the protocol is that all the state is encoded in the messages. 
Provided that messages are not re-ordered, the receiver always has the right key to 
decrypt the message. It does not have to remember old keys or interrupt the service 
during re-keying. This avoids the need of an extra state in the protocol for re-keying. 



Support for session scavenging 

Figure 13 Ping protocol 
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SLS needs an external mechanism to detect that the other party in the session is no 
longer active. This is required because of the independence of transport and session 
"lives". We cannot assume that the underlying transport will detect that the other 
party abandons the session. The transport won't necessarily send a TCP keep-alive 
message, for example. We have to provide that service at a higher level 

Figure 13 shows the basic support provided for session scavenging. An external 
client can check whether the session is active by forcing its endpoint to send a PING 
message and resetting a flag that indicates a reply ping arrived. If the reply ping 
arrives the flag is set. After a certain time the client checks whether the flag is set, 
indicating whether the other end is still alive or not. 
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Support for tunneling 

In SLS tunneling a PDU contains in its payload another PDU, so messages are sent 
using another SLS session as 44 transport 1 ' . When the initiator sends the first protocol 
message, (HandShakeStart in the current implementation), the responder might 
reply that it is not the final end-point, so it cannot prove what was requested, and it 
wants to be a relay instead. At that point the client can decide whether to continue 
the key agreement or not. If it continues it will get a ready session that was 
negotiated as a "relay" and it can use that session to negotiate another one to the 
end-point- If this new end-point also wants to be a relay the process repeats. 
Typically the maximum depth of session nesting is limited to a fixed value to avoid 
a denial-of-service attack. As implemented, the Session objects are stacked. An 
initial session (A) is connected to the transport; a session B nested in A is 
"connected" to A, and so on. However arranged, it should be transparent to the 
client. 

Figure 14 shows how to send messages from client to server and back after a nested 
session via an SLS gateway has been established. The diagram shows sender SPIs 
as initial characters with a colon, such as * A:" or "B:" The wrapped PDUs are 
bracketed. When a PDU passes through a session a layer of encryption is applied or 
removed. This is not shown in the diagram. 

A session will perform automatic wrapping of a PDU inside another PDU while 
sending when: 

• the sender SPI is valid (>0) 

• the sender SPI does not match the one the session is going through (we use 
sender and not receiver SPI because the receiver one is not guaranteed to be 
unique). 

In the current implementation, a PDU to be tunneled is initialized with an invalid 
sender SPI of -1. So session B just changes the sender SPI to *B* . When the PDU is 
passed to session A, the conditions for wrapping are satisfied. During the wrapping 
the addresses of the inner PDU are copied into the header of the external PDU. This 
is given the message-type TUNNEL. The resulting TUNNEL PDU gets unwrapped 
when it is handled by session A in the gateway. The reply is wrapped by session A 
in the gateway, and unwrapped by session A at the client end. This is default 
behavior that can be overridden by a custom handler. 
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Figure 14 Tunnelling SLS sessions 
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An important feature of the tunneling implementation is that a session can be used 
to tunnel messages regardless of whether the session was negotiated as a relay 
session or not. The opposite is also true, we can send non-tunnelled messages for a 
session that requested to be a relay session. In fact, how sessions are created is 
orthogonal to what type of messages can be sent through them. This simplifies the 
re-use of sessions but: 

• It can't be assumed that a message received in a normal session was not 
tunneled. 

• Tunneled messages, which may have several layers of wrapping and encryption, 
can not be assumed to have traversed a firewall, and are not necessarily any 
more secure than normal messages. 



Core to core communication 

Two e-speak cores can exchange core-managed resources and resource metadata. 
The exchanges comprise import and export of resources. They are needed for 
several reasons, including the following. 

• A resource cannot be discovered in a vocabulary on an e-speak core unless the 
vocabulary has been registered on that core. If the vocabulary was created on 
another e-speak core, it is registered by importing it. 

• A resource cannot be registered in a contract on an e-speak core, unless the 
contract itself has been registered on that core. If the contract was created on 
another e-speak core, it is registered by importing it. 

• Resource metadata can be imported into an e-speak core, to cache it. This will 
make lookup of those resources faster. 

Two core-managed resources handle communication between e-speak cores. 

• The Connection Manager CM, sets up the initial connection, manages it and 
closes it down. The ESName for the CM on any given e-speak core is: 
es://<server>/CORE/ConnectionManager 
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♦ The Remote Resource Manager (RRM) is responsible for managing metadata: 
importing and exporting resources from the remote e-speak core. The ESName 
for the RRM on any given e-speak core is: 
es://<server>/CORE/RemoteResourceManager 



The Connection Manager provides the core-to-core connection handling APIs. Each 
connection is associated with a Protection Domain, Outbox and an Inbox. The 
inbox and outbox along with the Router form the message forwarding subsystem to 
the remote core (see Figure 7). 

The core-to-core connection can be a secured channel: SLS messages may be 
exchanged to set up a secure chanel. 

class connect ionManager{ 

public synchronized String openConnect ion (String coreUrl) 1 
throws UnknownHo st Except ion 

public synchronized void closeConnect ion (String conID) 
throws UnknownHo st Except ion 

public synchronized CMArg closeConnectionFromRemote (CMArg 
cmArg) 

throws UnknownHostException 

public synchronized ESArray getConnections ( ) 



1 The coreUrl should be type ESname, in the current implementation it is type String. 




RRM: Remote Resource Manager 
CM: Connection Manager 



Figure 15 Core-core communication components 
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CM Methods: openConnection() 

The openConnectionO invocation is synchronous. The caller has to wait until the 
openConnectionO returns or times out (the current default time out period is 10 
seconds). The parameter is the URL of the remote core's root frame: a URL of the 
form es://host 

When the Connection Manager executes this function it sends a PDU message to the 
remote core. The toAddress of the PDU is set to es://host/CORE. (Note that only 
" es://hosf is the argument passed by the caller of openConnectionO •) The PDU is a 
messageForResource with a payload type of METHOD.CALL: the payload field is 
an instance of methodCall The methodCall.interface is " Core" and the method field 
is "bootstrap". The fromAddress is set to es://<localCore>/CORE, where 
<localCore> is the host and port for the Connection Manager's e-speak core. 2 

The messageType field of PDU is set to HANDSHAKE for this request in the current 
implementation. It should, for consistency, be APPLICATION„MESSAGE. 

Once the message has been sent, the Connection Manager waits for a reply PDU 
message. The remote core receiving the message replies with a bootstrapReply 
message (see "Initial Connection to the Core" on page 130). In the current 
implementation this reply is ignored. 

Next the Connection Manager sends a " negotiate" message to the remote core. This 
consists of an empty messageForResource instance (payloadType is set to OBJECT 
and the payload contains the null object). The toAddress of the PDU is set to es:// 
host/CORE/ConnectionManager. The fromAddress of the PDU is set to es:// 
<localCore>/CORE/ConnectionManager. 

Once this message is sent the Connection Manager waits for a reply from the remote 
Connection Manager. In the current implementaiton this reply is ignored. 

The returned value of openConnection is a String denoting the server and port of 
the remote core to which a connection has been made. Thus a connection to es:// 
foo.bar.com:8000/ returns a String: "foo.bar.com:8000\ This String can be used to 
identify the connection for later connection management operations. 



2 In the current implementation all URLs created by the connectionManager begin with "tcp://" 
instead of "es://" 
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Only one connection exist between 2 cores. Once the connection is established 
subsquent openConnectionO requests with the same parameter have no effect 

CM Methods: proposed future negotiation 

The " negotiate" message is a place holder for future extensions. The intended future 
behavior is as follows. 

1. Initiator builds a negotiation proposal, and sends the proposal to the remote core. 
The offer includes parameters such as Core Version, e-speak version and PDU size 
(for buffering, fragmentation and reassembly). 

2. The remote core then builds an offer based on the proposal and send the offer to 
the initiator. 

3. The initiator then builds the agreed upon offer and sends the final offer to the 
remote core. 

CM Methods: cioseConnection() 

The closeConnectionO function performs a graceful close of connection between 
the cores. The closeConnection API sends a "close" message to the remote core and 
requests to cleanup the resources allocated to this connection. Upon receiving the 
close request message from a remote core the Connection Manager initiates the 
clean-up process, thereby deallocating the resources assigned for the connection. 

The parameter conID to closeConnectionO is the String previously returned from 
openConnectionO- When closeConnectionO is invoked the Connection Manager 
sends a PDU containing a messageForResource instance to the remote Connection 
Manager. The MessageForResource has a payloadType of METHOD__CALL. The 
interfaceName is "ConnectionManagerlnterface" and the methodName is 
"closeConnectionFromRemote". The parameter CMArg is defined as follows: 

class CMArg { (ESF) 
String localURL; 
String remoteURL; 

int type; // CLOSECONNECTIONREQUEST=l CLOSECONNECTIONREPLY=2 
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The localURL field is set to the host+server port for the sending core for example: 
*initiator.bar.com:8080\ The remoteURL field is set to host+server port for the 
remote core. The type is set to CLOSECONNECTIONREQUEST. When the remote 
core receives this message, it can use the localURL, remoteURL pair to identify the 
connection. The remote core sends a messageForResource with a payloadType of 
METHODRESULT. The Ob field of the MethodResult class is an instance of 
CMArg. The localURL and remoteURL are unchanged, but the type field is set to 
CLOSECONNECTIONREPLY. Having sent this, the remote core closes the 
connection. When the initiating core receives this reply, it closes the connection. 

CM Methods: getConnections 

The function getConnections 0 returns the state of current connections. Each 
element of the returned ESArray is a String of the formed by the IP address of the 
remote host and the port number on which the remote e-speak core is located 
separated by a colon, e.g.: M host.foo.com:8000 w 



Remote Resource Manager 

The Remote Resource Manager (RRM) handles metadata related functions. It 
provide the capability to export and import resources to and from remote e-speak 
cores. 

RRM Message Class 

Instances of the class payloadForRRM are used as arguments or returned by the 
RRM: 

class payloadForRRM{ (ESF) 
int payloadType; 
boolean topLevel; 
int importExportMode; 
byte [] contextPDU; 
ESArray resourceTable; 
ESArray tabl es Array; 

The following are permissible values for payloadForRRM.payloadType: 

EXPORT_REQUEST=0; //Export Request 
EXP0RT_REPLY=1; //Export Reply 
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IMPORT_REQUEST=2; //import Request 
IMPORT_REPLY=3; //Import Reply 

UPDATE_EX PORTED_RESOURCE_REQUES T= 4 ; //Update Export Resource 
Request 

UPDATE_EXPORTED_RESOURCE_REPLY=5; //Update Export Resource 
Reply 

UPDATE_IMPORTED_RESOURCE_REQUEST=6; //Update Import Resource 
Request 

UPDATE_IMPORTED_RESOURCE_REPLY- 7 ; //Update Import Resource 
Reply 

UNEXP0RT_REQUEST=8; //Unexport Resource Request 
UNEXP0RT_REPLY=9; //Unexport Resource Reply 
IMPORT_ERROR=10; //Import Error 
EXP0RT_ERR0R=11; //Export Error 

RRM Class: 

class RemoteResourceManager{ 

void exportResource(ESName esname, boolean topLevel, int mode, 
String server) 

throws NameNotFoundException, StaleEntryAccessException 

PayloadForRRM importResourceFromMsg ( Pay loadForRRM rrmPayload) 
throws RemoteException 

void import Resource (ESName esname, boolean topLevel, int type, 
String server) 

throws ImportFailedException 

PayloadForRRM exportResourceAsMsg {PayloadForRRM rrmPayload) 
throws StaleEntryAccessException, NameNotFoundException, 
RemoteException 

void unExportResource (ESName esname, String server) 
throws RequestNotDeliveredException 

PayloadForRRM unExportResourceFromMsg (PayloadForRRM rrmPayload) 

throws NameNotFoundException, 

StaleEntryAccessException, 

QuotaExhaus tedExcept ion , 

I nva 1 i dNameExc ep t i on , 

PermissionDeniedException, 

Remo t e Exc ep t i on 

void updateExportedResource { ESName esname, boolean topLevel, int 
mode, String server) 
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throws StaleEntryAccessException, 
NameNotFoundException, 
RequestNotDeliveredException, 
Export Fai 1 edExcep t i on 

PayloadForRRM updateExportedResourceFromMsg (PayloadForRRM 
rrmPayload , 
String fromServer ) 

throws NameNotFoundException, 

StaleEntryAccessException, 

Permi s s ionDeniedExcept ion , 

InvalidValueException, 

Upda t e Fail edExcep t ion , 

Remot e Except i on 

void updatelmportedResource (ESName esname, boolean topLevel, int 

type, String server) 

throws NameNotFoundException, 

StaleEntryAccessException, 

RequestNotDeliveredException 

PayloadForRRM upda te Import edRes our ceFromMsg (PayloadForRRM 
rrmPayload) 

throws RemoteException 

void exportOnConnecting (ESName esname, boolean toplevel, int 
type) 

throws NameNotFoundException; 



RRM Methods: exportResourceQ 

void exportResource (ESName esname, boolean topLevel, int mode, 
String server) 

throws NameNotFoundException, StaleEntryAccessException 

The function exportResource exports the resource identified by esname to the 
server identified by server. The server parameter is a String of the form 
hostname:port, for example "foo.bar.com:8080\ The boolean topLevel indicates 
whether this is to be a recursive export (topLevel = false) or not (topLevel = true). 
A recursive export will export all resources that are referenced in the metadata of 
the resource identified by esname (vocabularies, contracts and the like). The mode 
parameter indicates whether this is to be export by reference or export by value. 
Export by reference copies the metadata but not the resource state. Any invocation 
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of the exported resource will invoke the same copy. Export by value exports the 
resource state as well as its metadata: an invocation of the resource on the remote 
core will result in an invocation of its own copy of the resource. Recognized values 
for mode are BY.VALUE (0) and BY.REFERENCE (1). Export by value is only 
supported for Core-managed Resources. The RRM will invoke 
importResourceFromMsg on a remote RRM to export the resource to that RRM. 
The payloadForRRM will have a payloadType field set to EXPORT_REQUEST. 

RRM Methods: importResourceFromMsg () 

PayloadForRRM importResourceFromMsg (PayloadForRRM rrmPayload) 
throws RemoteException 

CJ The function importResourceFromMsg is invoked by a remote RRM (B) to tell RRM 

II ( A ) to import the resource (s) contained in the argument rrmPayload, an instance of 

%l payloadForRRM. The payloadType field is set to EXPORT.REQUEST. The topLevel 

Ul fleld is set to faIse if th e import is to be recursive. The ImportExportmode field is 

ill set to BYVALUE (0) or BY.REFERENCE (1) . The contextPDU is not used by RRM 

i J i A * {t is returned to RRM B. The intent of this field is to enable RRM B to identify the 

ill context (typically an attempt to send a message) that caused it to invoke 

U importResourceFromMsg. 

u The ESName of each resource being exported is in rrmPayload.resourceTable. If 

% the export is not recursive, this will have only one element: the ESName of the 

f\ original resource passed to RRM A as the argument to exportResourceO . If the 

ill export is recursive, this ESArray will contain all the ESNames of resources included 

't\ in the metadata of the original resource and all the resources included in the 

\i\ metadata of these resources and soon on. If the export is BY_VALUE then resources 
included in resource state will also be included in the resourceTable. 

Each element of rrmPayload.tablesArray is itself an ESArray. There is an ESArray 
in tablesArray corresponding to each element in resourceTable. Each ESArray in 
tablesArray consists of four elements. 

Taken together these define the resource metadata and state for the resource 
identified by the ESName in resourceTable: 

• short typeCode 

• ResourceSpecification spec 
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• ResourceDescription desc 

• Object resource 

The following are permissible values for typeCode: 

INBOX_CODE » 0 
METAJRESOURCE_CODE = 1 
PROTECTION_DOMAIN_CODE = 2 
RE SOURCE_F ACT0RY_C0DE = 3 
CONTRACT_CODE = 100 
CORE_DISTRIBUTOR__C0DE = 110 
IMPORTER_EXPORTER_CODE « 120 
MAPPING_OBJECT_CODE =140 
NAME_FRAME_CODE = 150 
REPOSITORY_VIEW_CODE = 160 
SECURE_B00T_C0DE = 170 
SYSTEM_MONITOR_CODE = 180 
VOCABULARY^ CODE = 190 
CORE_MANAGEMENT_SERVICE__CODE = 200 
DEFAULT_VOCABULARY__CODE = 210 
DEFAULT_CONTRACT_CODE = 220 
FINDER_SERVICE_CODE =230 
CONNECT I 0N_MANAGER_C0DE = 240 
REMOTE_RESOURCE_MANAGER_CODE = 250 
EXTERNAL_CODE = 1000 

EXTERNAL_RESOURCE_CONTRACT_CODE « 1001 

ResourceSpecification and ResourceDescription are defined in Chapter 3, 
"Resource Data, Searches & Vocabularies". 

The resource field is omitted if the resource identified by the ESName in 
resourceTable is an external resource (typeCode = EXTERNAL_CODE). Otherwise 
the resource field is an instance of the Core-managed resource specified. It will 
contain the data members defined for this Core-Managed Resource type in Chapter 
4, Xore-Managed Resources*. The resource field is included even if the export 
mode isBY.REFERENCE. 

RRM Methods: importResourceQ 

void import Re source (ESName esname, boolean topLevel, int type, 
String server) 

throws Import Fa iledExcept ion 
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This method instructs the RRM to import the named resource from the server 
identified by the String server (the format of this String is host:port). The boolean 
topLevel is set to false if the import is to be recursive. Permissible values of the 
argument type are BY.VALUE or BY.REFERENCE. When this function is invoked 
on the RRM it sends a message to the remote RRM on the core denoted by the server 
parameter. This is a messageForResource, containing an instance of methodCall 
with interfaceName: "RemoteResourceManagerlnterface", methodName: 
"exportResourceFromMsg* and a single element in the argument array, of type 
payloadForRRM. The payloadType for payloadForRRM is IMPORT J^EQUEST. The 
importExportMode is set to BY.VALUE or BY.REFERENCE. The contextPDU field 
is used by the RRM to identify the context for the reply to this message. Typically it 
contains a serialized PDU. The resourceTable contains a single element: the esname 
parameter passed in the call of importResource. 

RRM Methods: exportResourceFromMsgO 

PayloadForRRM expor t Res our ceFromMsg (PayloadForRRM rrmPayload) 
throws StaleEntryAccessException, NameNotFoundExcept ion, 
Remo t e Exc ep t i on 

The function exportResourceFromMsg is called from a remote RRM in response to 
an invocation of importResource on the remote RRM. The rrmPayload parameter contains 
the data defined in the description of importResource. The returned PayloadForRRM is sent 
in a messageForResource which contains an instance of methodResult. This 
PayloadForRRM has type IMPORTJREPLY. The importExportmode, topLevel and 
contextPDU fields will be those contained in the original rrmPayload. The resourceTable and 
tableArrays contains the list of ESNames of resources, and their metadata and state as 
described in the description of importResourceFromMsg. 

RRM Methods: unExportResource() 

void unExportResource (ESName esname, String server) 
throws RequestNotDeliveredException 

The function unExportResource causes the RRM to try to unexport the resource 
from the remote e-speak core identifed by server (format "host:port''). It does this 
by sending and instance of methodCall with interfaceName 
" RemoteResourceManagerlnterface" , methodName u unExportResourceFromMsg" 
and a single element in the argument array of type payloadForRRM. The 
payloadType for payloadForRRM is UNEXPORT_REQUEST. The topLevel and 
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importExportMode fields are not used for this request. The resourceTable field 
contains a single element: the esname parameter to the function 
unExportResource. The tablesArray field is empy. 

RRM Methods: unExportResourceFromMsgQ 

PayloadForRRM unExportResourceFromMsg (PayloadForRRM rrmPayload) 

throws NameNotFoundException, 

StaleEntryAccessException, 

QuotaExhaustedException, 

I nva 1 i dN ameExc ep t i on , 

PermissionDeniedException, 

RemoteException 

The unExportResourceFromMsg is invoked from a remote RRM in response to a 
call of unExportResourceFromMsg on the remote RRM. The rrmPayload contains 
the data defined in the description of unExportResourceFromMsg. The intent is 
that the RRM receiving an invocation of unExportResourceFromMsg should 
remove the resource contained in rrmPayload from its repository. 
ThePayloadForRRM instance returned contains a payloadType of 
UNEXPORT_REPLY and the contextPDU passed in the rrmPayload parameter. All 
other fields are unused. 

RRM Methods: u pdate Exported Resource () 

void updateExportedRe source (ESName esname, boolean topLevel, int 

mode, String server) 

throws StaleEntryAccessException, 

NameNotFoundException, 

RequestNotDeliveredException, 

Export Fa iledExcept ion 

The effect of calling the updateExportedResource function is very similar to calling 
ExportResource. The difference is that the RRM will invoked the 
updateExportedResourceFromMsg function on the remote RRM (instead of 
ExportResourceFromMsg) and the payloadType of the PayloadForRRM instance 
passed as a parameter in the remote invocation will be set to 
UPDATE_EXPORTED_RESOURCE_REQUEST. 
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RRM Methods: updateExportedResourceFromMsgO 

PayloadForRRM updateExportedResourceFromMsg (PayloadForRRM 
rrmPayload , 
String fromServer ) 

throws NameNotFoundException, 

S t al eEnt ryAc ce s sExc ep t i on , 

PermissionDeniedException, 

InvalidValueException, 

UpdateFailedException, 

RemoteException 

The function updateExportedResourceFromMsg is invoked by a remote RRM when 
it wishes to update resources which have been exported previously. The intent is 
that the RRM receiving the call of this function replaces the metadata (and the state 
in the case of an export BYJVALUE) of each resource in the resourceTable in 
rrmPayload with the metadata and state contained in tablesArray. Only resources 
that have already been registered will have their metadata and state updated. The 
PayloadForRRM returned as the result will have the contextPDU of the rrmPayload 
parameter and a payloadType of UPDATE„EXPORTED„RESOURCE_REPLY t All 
other fields will be ignored by the remote RRM that invoked 
updateExportedResourceFromMsg, when it receives this result. 

RRM Methods: update Imported Resource () 

void update Import edResource (ESName esname, boolean topLevel, int 

type, String server) 

throws NameNotFoundException, 

StaleEntryAccessException, 

RequestNotDeliveredException 

The updatelmportedResource function is similar to the importResource function. 
The major difference is that the RRM has previously imported the resource 
identified by esname. The RRM will invoke the updatelmportedResourceFromMsg 
on the remote RRM identified by the String server (host:port). The PayloadForRRM 
passed as a parameter in updatelmportedResoruceFromMsg has payloadType of 
UPDATE JMPORTEDJtESOURCEJREQUEST and will have a single element in 
resourceTable; the ESname of the resource that needs updating. Note that this may 
not be the same ESName that is received as a parameter to 
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updatelmportedResource, it must be the ESName used to identify the Resource 
when it was originally imported. So the RRM must remember this information about 
imported resources if it is to request updates of metadata. 

RRM Methods: updatelmportedResourceFromMsgO 

PayloadForRRM updatelmportedResourceFromMsg (PayloadForRRM 
rrmPayload) 

throws RemoteException 

The function updatelmportedResourceFromMsg is invoked by a remote RRM when 
it has received an invocation of updatelmportedResource and needs to update a 
resource's metadata (and possibly state). The rrmPayload will contain the data 
described in the descripion of updatelmportedResource above. The 
PayloadForRRM returned from the updatelmportedResoruceFromMsg function 
has a payloadType of UPDATE JMPORTED_RESOURCEJ?EPLY. The topLevel, 
importExportMode and contextPDU fields will be the same as in the rrmPayload 
parameter. The resourceTable field and tablesArray respectively contain the 
ESnames and metadata (and possibly state) of the resources to be updates. Note 
that even though a single resource ESname is all that is contained in the rrmPayload 
parameter, the result can contain many ESnames if the topLevel flag is set to false 
(indicating recursive import/export). 

RRM Methods: exportOnConnectingO 

The resource is added to the list of resources to be exported when connection is 
established. The parameter esname is the ESName of the resource to be exported. 

The parameter toplevel is set false if export is to be recursive. 

The parameter type indicates the type of export. It can take the value BYVALUE (0) 
orBYREFERENCE (1). 

Restrictions on import and export of core managed resources 

The following Core-managed Resources cannot be exported or imported. 

• Protection Domain 

• Meta Resource 
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• Resource Factory 

• Inbox 

• System Monitor 

• External Resource Contract 

The Account Manager cannot be exported by value, only by reference. 

Other Core-managed Resources have restrictions when exported by reference. In 
particular, such a Resource cannot be used as part of message processing as shown 
in Table 10 

Table 10 Core-managed Resource export restrictions 



Resource 


Pass by reference restrictions 


name-frame 


Cannot be used as a component of an ESName sent to the 
Core for name resolution 


Repository View 


Cannot be used in a Search Recipe 


Resource Contract 


Cannot register a Resource in this Contract 


Vocabulary 


Cannot be used in a Search Recipe 



Removing imported resources (informational) 

The Connection Manager provides the closeConnectionO function to perform a 
graceful shutdown of a connection. The Connection Manager builds a close 
connection message and sends the message to the Connection Manager of the 
remote core, requesting the connection cleanup process. In the current 
implementation, the Connection Manager on the remote core removes the 
Protection Domain, Outbox and other resources allocated to the connection. 
Removing the Protection Domain used for the connection will remove all resources 
that have been imported from the connection (as they are registered in this 
Protection Domain). 

The initiating core also performs similar clean up process. The Protection Domain, 
Outbox assigned to the connection are removed. 
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ESnames denote an access path to a resource. ESnames conform to the format and 
grammar defined for Universal Resource Identifiers (URIs) [see RFC 2396\. 
ESNames are therefore URIs and mores specifically, since they denote the access 
path for the resource, ESNames are also Universal Resource Locators (URLs). 
ESNames have the following format. 

es : //<host>/<relative path> 

The host part of an ESName is either the host name or the IP address of the host on 
which the e-speak core is located together with an optional port number. If the port 
number is not specified, the current implementation will throw an exception. 
Discussions are underway with IANA for a standard port number to be assigned. 

The full form of an ESName (es://<host>/<relative path>) is known as an absolute 
ESName. Subsets of this syntax also denote ESNames (see "ESName BNF tt on page 
169) . However, it may not be possible to resolve such ESNames if we do not have 
the necessary context. 

The relative path component of an ESName must be unique on the given e-speak 
core. The path is relative in the sense that it is given a global context by the <host> 
element of the ESName. If the <host> element is missing (e.g. es://path or es:/path) , 
then the resolver must decide the global context in which to begin resolution. 
Usually the global context is assumed to be the current host 

The path consists of a set of Strings separated by Y, for example " a/b/c" . The path 
is resolved by taking each String element in order and resolving that in the current 
name-frame. If this returns a name-frame the next element is resolved in that name- 
frame. The process continues until there are no more elements in the path in which 
case we have resolved the ESName to the intended resource. The first element will 
be resolved in the root name-frame of the e-speak core denoted by the server part 
of the ESName. For example, taking u a/b/c", * a" is resolved in the e-speak core s 
root name-frame to return a name-frame which we denote NF(a). Next b is resolved 
in NF(a) , to return a name-frame which we denote NF(a b). Finally c is resolved in 
the name-frame NF(a b). 

If a String element of the path component other than the final component fails to 
resolve to a name-frame, name resolution has failed. If the final element fails to 
resolve to a resource, name resolution fails. 
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When a client registers a resource with an e-speak core, the default name-frame for 
that resource, is root name-frame of the client s protection domain. 

If two clients on the same host bind two different resources in their root frames 
under the same relative path (e.g /a/resource) they will have different absolute 
ESnames even though the host part is the same: 

es : //host/clientlPDRootFrame/a/resource and 
es : //host/client2PDRootFrame/a/resource 

If a client terminates and its protection domain is not persistent, there will be a 
recursive deletion of all names within the protection domain's root name-frame. 
This means any URLs handed out rooted in this name-frame will be invalid. To 
overcome this, a resource needs to be bound in a name-frame which is persistent.To 
stop the deletion of a non-persistent protection domain causing a deletion of 
persistent resources, the current implementation prohibits a persistent resource to 
be bound within a non-persistent Protection Domain. 

Core name-frame and core root name-frame 

Every e-speak Core has a Core Name-Frame with the following ESName. 
es : //<hostport>/core 

The names of various core managed resources are bound within this name-frame, 
including vocabularies, contracts and the metaresource. The following names are 
currently used. 

/Core/MetaResource 
/Core/ResourceFactory 
/Core/ Sy s t emMoni tor 
/Core/Finder 

/Core/ CoreManagement Service 

/Core/Def ault Vocabulary 

/ Core/BaseDistributorVocabulary 

/Core/CoreDistributor 

/ Core / Connect i onManage r 

/ Cor e /Remo t eRe s our c eManage r 

/Core/AccountManager 

/ Core/ BaseAc count Vocabulary 

Every e-speak Core has a root name-frame which is denoted: 
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es : //<hostport>/ 

or, alternatively, assuming the <hostport> part is already known to the resolver: 

es : / 

The following names are bound in the e-speak Core root name-frame: 
/Core 

/ Coritrac t Cont rac t 
/Vocabulary-Contract 

Canonical ESName 

This is the ESName stored in the URL field in the Resource's ResourceSpecification 
(see Chapter 3, "Resource Data, Searches & Vocabularies"). This ESName is 
guaranteed always to be valid as long as the Resource is registered. It does not 
depend on any binding maintained in a Client s name-frame. Cannonical ESNames 
have the following form: 

es : //<hostport>/proc/resource/<type_string>/<unique_id> 

The <hostport> field is of the form host name or IP address followed by a port 
number separeted by a ":" as specified in [RFC 2396\, 

The following are the permissible values of <type__string>, they denote the 
Resource Type (see Chapter 3, "Resource Data, Searches & Vocabularies") 

"Inbox" 

"MetaResource" 

" Pro t e c t i onDoma in " 

( "ResourceFactory" ) 

( " Connect ionManager 11 ) 

( "RemoteResourceManager " ) 

"Contract" 

( "CoreDistributor" } 

" Ext er na lRe s our ce " 

11 ExternalResourceContract " 

( " Import erExporter" ) 

{ "MappingObject" ) 

"NameFrame " 

" Repos i t or y V i ew " 

("SecureBoot") 

" SystemMoni tor " 

( "AccountManager " ) 
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"Account " 
"Vocabulary" 

{ " CoreManagementServi.ee" ) 
"Finder" 

The field <uniquejd> is the Stringified form of a number (in the current 
implementation this is the repository handle). 

The terms bracketed are permissible values of <type_string>, but will normally be 
bound in the Core Name-Frame described above (es://<hostport>/core). If so, they 
will not occur under es://<hostport>/proc/resource. 

Queries and fragments 

Queries and fragments are also allowed in ESNames. A query is the data that follows 
the H T in an ESName of the form: 

es : //<host>/<relative path> ? uric* 

A fragment is the data that follows the in an ESName of the form: 

es : //<host>/<relative path> # uric* 

The character set uric is defined in \RFC2396\ which also specifies constraints on 
the data in queries and fragments. 

Queries and fragments are not used in name resolution and are never interpreted by 
the e-speak core. They are delivered to the resource handler as part of the message. 

ESName class definition 

class ESName { 
String hostPart ; 
String [] pathPart ; 
} 

The above class defines the hostPart consists of the portion of the ESname from 
* es://" to the first T . In an ESName the path separator is T . This separates elements 
of the path. Each element of pathPart consists of an element in the path, without 
anyT character. 
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ESName BNF 

Here is the BNF for ESNames. Please refer to [RFC 2396[ for any element not 
defined directly. 

ESName = [ absoluteESname | relativeESname ] [ fragment ] 
absoluteESname = es " : " hier_part 

relativeESname = { net_path | abs_path | rel_path ) [ "?" query ] 

hierjpart = ( net_jpath | abs_path ) [ "?" query ] 

net_j>ath = "//" hostport [ abs_jpath ] 
abs_path = "/" pathjsegments 
rel_path = rel_segment [ abs_path ] 

rel_segment = 1* ( unreserved | escaped j " ; " | "@ M | "& M | " = " 

hostport = host [ " : " port ] 
host = hostname | IPv4 address 

hostname = * ( domainlabel " . " ) toplabel [ 11 . n ] 
domainlabel = alphanum | alphanum *( alphanum | " ) alphanum 
toplabel = alpha | alpha * ( alphanum | " - " ) alphanum 
IPv4address = l*digit " . " l*digit " > " l*digit l*digit 
port = *digit 

path_segments = segment *( "/" segment ) 
segment = *pchar * ( " ; " param ) 
param = *pchar 

pchar = unreserved | escaped | " : " | "@ M | | " = " | " + " | "$" 

query = *uric 

fragment = *uric 
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A PDU is transmitted as a 32 bit length (in network byte order), followed by the 
buffer containing the PDU itself. 

All data inside a PDU is marshalled in network byte order. 

• int is a 32 bit integer 

• long is a 64 bit integer. 

• short is a 16 bit integer 

• char is a 16 bit character 

• boolean is marshalled as a single byte (0x01) for true (0x00) for false. 

• String is marshalled as a 1 6 bit length followed by each character in the String as 
16 bits per character 

• byte[] is marshalled as a 32-bit length followed by the bytes. 

• ADR are marshalled by converting them to ASCII canonical s-expressions 
defined in " SPKI BNF Formats" (Chapter 5, u Access Control" ) and then marshalled 
as a byte array using marshalBytes. 



E-speak Serialization Format 

The basic types recognized are byte, short, int, long, float, double, and 
string. The four integral types byte, short, int, and long are 1, 2, 4, and8bytes 
long respectively, and are always sent most significant byte first. The float and 
double types are sent just as in Java. The string type is intended to contain text 
rather than arbitrary binary data, and the text must be a valid UTF-8 encoded string 
as per [RFC 227$. It is hoped that "string 1 * will not be confused with 
java.lang.String. 

We also recognize arrays of types. The type foo[] is sent as a length followed by that 
many instances of type foo. If the length is -1, then a NULL is returned. If the length 
is 0, an empty array is returned. Otherwise an array with that many elements is 
returned. 
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A map is sent in the same syntactic way as an array, but there is an implicit Key/ 
value association between pairs of elements; all the evenly indexed elements (0, 2, 
etc.) are Keys, and all the odd indexed elements are values. Some maps may allow 
multiple occurrences of the same Key. 

The length field is encoded in a single byte if the value of the length is 4. .62 
inclusive; the encoding is 129 more than the length. Thus, -1 is sent as the byte value 
128, and a length of 3 is sent as the byte value 132. Lengths from 63..2 A 31-1 are sent 
as a 4 byte integer. Lengths below -1 or greater than 2 A 31-1 are illegal at the present 
time. 

All elements are sent as a signal byte that indicates the type of the object that 
follows, followed by the data for that object. 

Signal bytes are entirely single bytes. They are encoded by literal ASCII characters 
(e.g., A) , literal ASCII characters but with the high byte set (char) (T+128)). 

Here is the Backus-Naur Form (BNF) for * Ob" an object serialized in the e-speak fo 
rmat, using the signal bytes defined currently. 



Ob 
D 
S 
[ 

c 
C 
] 



1 E 1 , <RSD > | 

<ResourceDescription > | 
<Re source Spec if ication 
<ESUID >| 

<SearchPredicate > | 

<SearchRecipe >| 

< Vocabul aryDe c 1 arat i on 

Preference > 

<FilterSpec > 

< At tribute Property > | 

<AttributePropertySet > 

<Attribute > | 

<AttributeSet > | 

<Value >| 

<ValueType > | 

<ESName > | 

<ESString >| 

<AttributePredicate > | 

<NamedObject >| 

<Prof ileAttributeSet > | 

<UserProf ile > | 

<NameSearchPolicy > | 

<FinderResults > 

<FinderContext > 
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'Q* , <CoreEvent > | 
' e » , <Event > | 
' t * , <EventAttributeSet > | 
' Z * , <ESRuntimeException> j 
'z\ <ESException>| 
(char) < 'z' +128) , <ESArray > 
(char) ( »s f +128) , <ESSet >| 
(char) (*I»+128) , <Integer> i 
(char) ( » J*+128) , <Long > | 
(char) ( ' B 1 +128 ) , <Boolean >| 
(char) ('y' +128) , <Byte >| 
(char) ( >c»+128) , <Character 
(char) ('W +128) , <Short >| 
(char) ( 'F' +128) , <Float >| 
(char) ( , D'+128) , <Double > 
(char) (»S'+128) , <String > 
(char) ( 'Z'+128) , <boolean[' 
(char) {'b'+128) , <byte[] > 
(char) CC+128) , <char[] > 
(char) ( 'W+128) , < short [] >| 
(char) Ci'+128) , <int [} >| 
(char) (• j '+128) , <long[] >| 
(char) ff »+i28) , <float [] > I 
(char) (»d'+128), <double[] > 
(char) { 'v' +128) , <Object[] 
(char) ( »H»+128) , <ESMap >| 
' I ' , <PayloadForRRM > | 
1 : ' , <CMArg >| 
'h', <RepositoryHandle >| 
'r 1 , <Contract >| 
'W', <RepositoryView >| 
1 V , <Vocabulary >| 
'm', <MappingObject >| 
' s • , <NameFrame > | 
' o T , <Binding >| 
' ? 1 , <ProtectionDomain > I 
'%', <Inbox >| 
f @', <ExternalResource >) 
1 A| , <SystemMonitor >| 
' + ' , <ResourceFactory > | 
*y' , <Finder >| 
'n 1 , <ConnectionManager >| 

<RemoteResourceManagei , 
<CoreManagementService > 
<AccountManager > 



> 



•d 



sr > 
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E-speak Serialization Format 



The components for each of the remaining non primitive type are defined in the 
relevant sections of this specification (to do: need to pull these definitions in 
to complete the BNF). 

In the following BNF, the meta-symbol => means "is sent as.* The convention is as 
follows: 

String => string 
Integer => int 
Long => long 

Boolean => byte 
Null = > 

Byte Array -> bytet] 
ObjectArray => Ob[] 
ESMap => map 
ESArray => Ob[] 
ESSet -> Ob[] 
ESList Ob[] 

ESMap, ESArray, ESSet and ESList in the current implementation are marshalled 
using Java serialization. 
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Chapter 7 Exceptions 



E-speak defines a set of exceptions to inform Clients when an error occurs in the 
system. Two classes of exceptions are defined: run-time exceptions and 
recoverable exceptions. 



Run-Time Exceptions 

Run-time exceptions are thrown when programming errors occur. A program 
catching such exceptions may terminate. ESRuntimeException has the 
following subclassed exceptions: 

• CorePanicException is thrown when the Core is unable to process the 
request. Although the Core attempts to notify all Clients of its inability to 
continue operating, it also replies with this exception for as long as it can. The 
Core can continue to accept new messages as the problem may be limited to the 
execution of a single message. 

• ServicePanicException is thrown when a service is unable to process the 
request. This can be a terminal error for the service, in which case the service 
exits. Or it can simply mean that the request being processed caused an internal 
error that was not recoverable, and the service accepts new requests. 

• RepositoryFullException is thrown when the request attempted to add 
additional information to the Core s Repository, but the Repository was full 
This exception can be recovered from if the Client is able to delete one or more 
Resources from the Repository. It is a run-time exception because almost every 
message can possibly throw this exception, and the Client has no guaranteed 
recourse (because some other application can consume the Repository space 
freed up by this Client). 
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• Outof OrderRequestException is thrown when the state of the system is 
inconsistent with the request. 

• ConnectionFaiiedException is thrown when the Connection Manager fails to 
establish a connection, details are contained in the exception state. 

• Inval idParamet erExcept ion is thrown by any other programming errors. 
This exception has three subclasses: 

• NullParameterExcept ion is thrown where a null parameter was 
supplied but is not allowed. This error is often caused by passing an 
uninitialized object. 

• InvalidValueExcept ion is thrown when a parameter is outside the 
allowed range. 

• Inval idTypeExcept ion tells the programmer that the name specified is 
bound to the wrong type of Resource. 



Recoverable Exceptions 

Recoverable exceptions occur due to a problem with the state of the system. For 
example, when the Client sends a message to request access to a Resource, the 
message may be undeliverable, perhaps because the Handler's Inbox is full. 
Recovery for this case can be as simple as resending the message. 

The base exception is ESExcept ion. This exception is subclassed into three major 
categories: ESLibException, ESInvocationException and 
ESServiceException. 

ESLibException is the base class for client library exceptions. It should not be 
thrown itself but rather a subclass exception.Currently one subclass is defined. 

* CoreNotFoundExcept ion indicates that a core could not be found to connect 
to. Either change the specification of the core or insure the core is running to 
correct this exception. 
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ESlnvocationException is a base class for all the exceptions that can be 
thrown by the Core back to the Client occurring during the processing of the 
request Exceptions thrown by most handlers are included here to reduce the 
number of explicit classes of exceptions that must be caught This exception is 
further subclassed into: 

NamingException results from a wide variety of problems. Regardless of the 
cause, this exception, or any of its subclasses, is thrown only for the primary 
Resource of the message header. Five subclasses are defined: 

• NameNot FoundExcept ion is thrown when the name resolution process failed 
to find a given name. The Client can recover by changing ESName. 

• EmptyMappingExcept ion is thrown when a Mapping Object is associated 
with the name, but that Mapping Object has no usable accessors. This condition 
arises when the accessor has no elements, the elements refer to unregistered 
Resources, or the Resources did not pass the visibility tests. The Client can 
recover by changing ESName or trying again with a different set of Keys. 

• UnresolvedBindingException is thrown when all the accessors of the 
Mapping Object are search requests. The Client can recover by requesting a 
lookup using the search request. 

• MultipleResolvedBindingException is thrown when the Mapping 
Object has more than one explicit binding. 

• LoopDetectedException is currently unused. 

StaleEntryException is thrown if the Resource no longer exists. The Core 
removes any stale handles from the Mapping Object before returning the exception. 
A retry does not result in this exception unless another referenced Resource has 
been unregistered. 

PermissionDeniedException is thrown by any Resource Handler when the 
client is not authorized to access the Resource. The Client can recover by retrying 
with a different set of certificates. One subclass is defined 

• SessionRequiredException is thrown when a client attempts to send it a 
message without first setting up a session. The service has security enabled and 
is performing access control checks. A secure session is needed so that the 
access control check can be made. This would normally be handled by the client 
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library and is transparent to the application programmer. The client recovers 
from this exception by exchanging SLS messages with the service to establish a 
session, 

QuotaExhaustedExcept ion is thrown when the Client attempts to define more 
Resources than it is allowed as defined by the quota assigned. The Client can delete 
other Resources (thus freeing up quota) and reattempt the request. 

MethodNotlmplementedException is thrown when the Client attempts to 
invoke a method on a Resource that is not implemented even though the method is 
consistent with the type of the Resource. This is typically used to "stub-out* 
routines when a service is under development. 

RecoverableCoreException is thrown when there is a problem while 
processing the request. There are two associated subclass exceptions: 

• RequestNotDeliveredException is thrown when the Core never started 
processing the message. This exception can be thrown by the Client library if it 
implements time-outs or in by the Core if the corresponding queue is full. It may 
be possible to recover from this exception by resending the message. 

• PartialStateUpdateException is thrown when the Core cannot finish 
processing the message. The Client may need to find out what state was changed 
before attempting recovery, for example, by examining the state of the 
metadata. 

TimedOut Except ion is thrown when a message being written to or received from 
a channel has not successfully completed within the caller defined time period. 

UndeliverableRequestException is thrown when the message cannot be 
delivered to the Resource Handler. In the current implementation, this is not 
thrown with security enabled, the security subsystem silently ignores such 
messages (in case they are a denial of service attack) and the Client has to wait for 
a TimeOutException There are two subclass exceptions of 
Unde liver ab 1 eRe que s t Exc ep t i on: 

• RecoverableDeliveryException is due to temporary conditions such as a 
full Mailbox. Recovery can be as simple as retrying. 



178 



Developer Release X.03.03.00, September 2000 



Exceptions 



Exception State 



• UnrecoverableDeliveryExcept ion is due to a condition that is unlikely to 
change quickly. The Client can recover by selecting a binding that points to a 
different Resource Handler. 

ESServiceException is a base class exception for all service-defined 
exceptions. 

• ESNameFrameException is the super class of all name frame exceptions.This 
allows the client to catch this exception and handle all the name frame related 
exceptions in one catch block. 

• NameColl isionExcept ion is thrown when the name specified in an 
add, copy, or similar operation is already defined in the Name Frame. 

• LookupFailedException is thrown when no Resources are found that 
match a Search Recipe. 

• invalidNameException is thrown when a string designating a name is 
not found in the Name Frame. 

• ESRemoteException is thrown if the Remote Resource Manager operation 
failed for any reason, details are in the exception state. 



Exception State 

Each exception has the following state. 

class ESException { 
int errno ; 
Object [] info; 

} 

The field errno indicates the type of the exception as shown below. 

NONE= 0 

ESRuntimeExceptions (1-99 reserved) 

INVALID_PARAMETER= 1 

NULL_PARAMETER= 2 

I NV AL I D_V ALUE = 3 

INVALID_TYPE= 4 

OUT OF_ORDER REQUEST= 5 
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CORE_PANIC= 6 
SERVICE__PANIC= 7 
REPOSITORY_FULL= 8 

ESExceptions (100-999 reserved) 
INVOCATION- 100 
NAMING- 101 
NAME_N0T_F0UND= 102 
EMPTY_MAP P ING= 103 
UNRESOLVED_BINDING== 104 
MULTIPLE_RESOLVED — BINDING- 105 
PERM I SS ION_DENI ED = 106 
QUOTA_EXHAUSTED= 107 
STALE_ENTRY_ACCESS= 108 
RECOVERABLE_CORE= 109 
PART I AL_S TAT E_JJP DATE = 110 
REQUEST_NOT_DELIVERED= 111 
UNDELIVERABLE_REQUEST= 112 
UNRECOVERABLE__DELIVERY= 113 
RECO VERABLE_JDEL I VERY- 114 
TIMED_OUT= 115 
METHOD__NOT_IMPLEMENTED= 116 
LOOP_DETECTED= 117 
SESSION_REQUIRED= 118 
CONNECTI ONFAI LED= 119 

E-speak defined service exceptions 

SERVICE = 2 00 



Name frame service exceptions 

NAME FRAME- 2 01 
I NVAL I D__NAME - 202 
NAME_COLLISION= 203 
LOOKUP_FAILED= 204 

Import/Export service exceptions 

REMOTE= 210 

Client Library defined exceptions 

ESLIB = 950 
CORE_NOT_FOUND= 951 

Exception numbers 1000+ are reserved for application use 
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Exception hierarchy 

Here is the exception hierarchy. Indentation indicates position in the hierarchy. 

E S Runt ixne Exc ep t i on 

ServicePanicException 
OutofOrderRequestException 
CorePanicException 
Connect ionFai ledExcept i on 
Repos i toryFul lExcept ion 
Connect ionFailedException 
Inval idParameterException 

Inval idTypeExcep t ion 

Inval idValueExcept ion 

Nu 1 1 Parame t er Exc ept i on 
ESException 

ESLibException 

CoreNotFoundException 
ESServiceException 

ESRemoteException 

ESNameFrameException 

Name Co 1 1 i s i onExc ep t i on 

I n va 1 i dName Exception 

LookupFai 1 edExcep t ion 
ESInvocationException 

StaleEntryAccessException 

PermissionDeniedException 

SessionRequiredException 

QuotaExhaustedException 

MethodNotlmplementedException 

RecoverableCoreException 

Part ialStateUpdateExcept ion 

RequestNotDeliveredException 

NamingException 

MultipleResolvedBindingException 

UnresolvedBindingException 

NameNotFoimdException 

LoopDetectedException 

EmptyMappingException 

TimedOut Except ion 

Unde 1 i verabl eReques tExcep t ion 

RecoverableDeliveryException 

UnrecoverableDeliveryException 
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Chapter 8 Core Generated Events & Event 

Distributor Vocabularies 



The e-speak event service is described in the E-speak Programmer's Guide. The 
Core itself is an example of an Event Publisher. It sends Events to an external Client 
called the Core Distributorto signal state changes such as a change in a Resource s 
attributes. The Core Distributor can then distribute these Events to interested 
Clients that have appropriate authority. 



Events 

An e-speak Event is a set of named attributes, where each attribute is a name-value 
pair. An Event also contains a reference to an e-speak Vocabulary. The Vocabulary 
enumerates the names of allowed attributes and their types. Specifying a 
Vocabulary in an Event makes the Event content self-describing. A recipient of a 
self-describing Event does not need to know anything about the Event s content a 
priori] it can query the Vocabulary to determine the Event s attributes and their 
types and then extract the values of the attributes it is interested in. Event 
generators can choose to leave the vocabulary field null, in which case Event 
attributes must be agreed upon a priori, the default meaning being the e-speak Base 
Vocabulary. 

An Event is defined as follows: 
class Event 

{ 

String eventType; 
EventAttributeSet eventAttrs; 
EventAttributeSet controlAttrs; 
Object payload; 
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Every event has a string that describes the event type and two AttributeSets (sets of 
name-value pairs). The first AttributeSet is the attributes that describe the event. 
The second AttributeSet are control attributes that intermediating entities (such as 
distributors) can insert into the event. Matching (filtering) can only be performed 
on the event attributes, not on the control attributes. A string is valid for eventType, 
the meaning of the string is application dependent. 

EventAttributeSet contains an AttributeSet (xref to chapter on 
resourceDescriptions, section on Resource Description defines AttributeSet): 

class EventAttributeSet extends AttributeSet 

{ 

AttributeSet attrs; 

String format; 

} 

The string format indicates the format of each Attribute in the AttributeSet attrs. 
" VOCAB* means that the attributes have to be valid in the vocabulary references in 
the AttributeSet attrs. "SIMPLE" means the attributes are simple (name, value) pairs 
and no valid vocabulary is specified in attrs. 



Core Generated Events 

The Core is a Publisher of Events. All Events published by the Core go to a single 
service called the Core Distributor Service. This service is the Resource Handler 
for several Distributor Resources, each dealing with a Core-generated Event of a 
different type. These are: 

• Changes to the state of the Repository 

• Changes to the state of Core-managed Resources 

These types are used to maintain the coherence of metadata and the Resource state 
shared by value. Both are described in the Base Event Vocabulary. 

The string in the eventType field for events generated by the e-speak Core consists 
of a prefix indicating the component that generated the event, followed by further 
information (such as the name of the method being invoked). 
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The eventAttrs field consists of a set of name, string-value pairs. Two common 
examples are: 

• name " Name" , value is the stringified version of the ESUID of the Resource 
responsible for generating the event 

• name "FailureDetaiF , value is a string indicating the nature of the failure 
The format string of the EventAttributeSet eventAttrs is "SIMPLE" . 

The payload field is null for events generated by the e-speak Core. 

The following is the list of prefix strings used by the current implementation. 

" core . mutate . NameFramelnterf ace . " 

" core . mutate . MailBoxInterf ace . " 

"core .mutate . Protect ionDomainlnterf ace . " 

" core . mutate . RepositoryViewInterf ace . " 

" core . mutate . Vocabulary Inter f ace . " 

" core . mutate . VocabularyToolBoxInterf ace . " 

" core . mutate . ResourceFactorylnter f ace . " 

" core . mutate . ResourceManipulat ionlnterf ace . " 

" core . mutate . ImporterExporterlnterf ace . " 

"core .mutate . SecureBoot . " 

"core . failure . " 

"core. failure. except ion. " 

"notifySync" 

"notify" 

"publish" 

" subscribe " 

"unpublish" 

"unsubscribe " 

"net .espeak. services . events . intf .ESListenerlntf " 

"net . espeak . services . events . intf . Distributorlntf " 

"net . espeak . j esi . event . coredist . ESCoreDistributorlntf " 

"net . espeak . infra . cci . events . Event " 

"service . create" 

"service. delete" 

"service .mutate" 

" service . access " 

"service. pause" 

M service . resume " 

"service .panic" 

"service .genericlnfo" 

"management . service . create" 

"management . service . coldreset " 
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"management . service . warmreset" 

"management . service . stop" 

"management . service . start " 

"management . service . shutdown" 

"management . service . remove " 

"management . service . error" 

"management . service > info" 

"management . service . illegal state" 

"management . servicemanager . newservice" 

"management . servicemanager . deleteservice" 

"management . servicemanager . servicechanged" 

" resource . change_jstate " 

" resource . invalid^ state " 

"resource . invalid_state_ transition" 

" resource . statistics" 

" resource . proxy_created" 

" coremanager . info" 

" coremanager . warning" 

" coremanager . serious " 



Publication of Core-generated Events 

The e-speak core sends events to the core distributor as a Protocol Data Unit 
containing a MessageForResource (xref to ESPDU section in communications 
chapter) . The payload field of the MessageForResource is the event. The payloadType 
of MessageForResource is set to EVENT. 

The e-speak Core does not subscribe to the Core Distributor (as an ordinary Client 
would). 
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A vocabulary is defined in which Distributors can be registered. 
Table 11 Distributor vocabulary 



Attribute 
Name 


Value Type 


Comment 


Meaning 


Name 


String 


Default value 

"BaseDistributorVocabufary" 




Type 


String 






ESGroup 


String 






ContractNam 
es 


String 






ServiceName 


String 




Name assigned to Distributor 


ServiceType 


String 




Type of distributor 


EventTypes 


String 


Multivalued 


Event types handled 


Persistent 


Boolean 


always false 


True if Distributor state survives Core 
restart 


Buffered 


Boolean 


always false 


True if Distributor is able to accept 
events faster than it can forward 
them 


Secured 


Boolean 


always false 


True if event state is tamper proof 


QOSLevei 


Integer 


always 0 


Quality of service level assigned by 
Distributor 


Multiplexed 


String 


Multivalued 


Type of aggregation and 
summarization 
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The Service Name, Service Type, and Event Types are strings that are assumed to 
have meaning to Publishers and Subscribers who have discovered the Distributor. 
For example, the Core Distributor could be described with a Service Name of 
"Core", a Service Type of "Core", and Event Types of "Repository" and "Metadata". 

The Persistent, Buffered, Secure, and QOSLevel attributes must be set as shown 
because the current Distributor implementation does not support these features. 
The Multiplexed attribute can be set by Distributors to describe how they combine 
events. For example, a Distributor can aggregate billing events from a particular 
customer and publish an aggregate event to the subscribers. The values assigned 
are assumed to have meaning to the Publishers and Subscribers of the events. 



Events in a Distributed Environment (Informational) 

Events are messages that trigger special actions by the recipients. In particular, 
when a Client receives an Event, the callback registered for this Event is invoked. 
It would be inappropriate for the Remote Resource Handler to invoke the callback. 
In fact, the Remote Resource Handler has no idea what to do with the Event. As 
currently implemented, no special action is needed. The result is delivery of the 
Event to the Client with no special action on the part of the Remote Resource 
Handler. 

The state of Resources exported by value and the metadata of all exported 
Resources is not synchronized by default. Clients wishing to synchronize exported 
or imported Resources register for the Core-generated metadata and Resource 
Events. They also subscribe to the Resource Event if the Core-managed Resource 
is being exported by value. 

Care is needed to avoid cycles. Consider an exported Resource that has its 
metadata changed on the importing side. Assume that a Client on each Logical 
Machine has subscribed to metadata Events for this Resource with Core 
Distributors from both Logical Machines. When one Client makes a change, they 
both get the Event. 
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Even if the Client making the change doesn't respond to the change Event, the other 
Client must make the change on its Logical Machine. This change can generate an 
Event that reaches the first Client. Not having any knowledge of the source of the 
Event, the Client makes the change again. These two Clients continue repeating the 
same change forever except for the fact that the Core generates a Resource or 
metadata Event only if the state is actually changed. Hence, the second change on 
each side does not generate an Event, and the cycle is broken. 

Other cycles can occur. Two Clients that make changes to the metadata while the 
Events are propagating can generate a cycle that is not broken so simply. The 
problem is that they are both changing the same item without synchronizing. Such 
conditions are almost certainly programming errors. No action taken by any e- 
speakcomponent can be guaranteed to break such cycles. Only the Clients have 
sufficient information to detect the problem. 
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Two concepts underpin the manageability of e-speak Resources and Clients. 

• Managed State: a defined service state embodying the life cycle of a service. 

• Managed Variable Table: sets of values that can be affected by a manager for the 
purposes of configuration and control. 

Managed Life Cycle 

The full state transition diagram is as follows. 
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Figure 16 Managed Service Lifecycle 



State Descriptions 

Initializing 

The internal dynamic state of the service is being constructed, for example: a policy 
manager is being queried for configuration information and resources are being 
discovered via search recipes or yellow pages servers. When the service finishes 
this work it moves asynchronously into the ready or error states. 

Ready 

The service is in a ready to run situation, this state is also equivalent to a stopped or 
paused state. 
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Running 

The service is running and responding to methods invoked on its operational 
interfaces. If an error occurs which implies that the service cannot continue to run 
it should move into the error state. 

Error 

The service has some problem and is awaiting management action on what to do 
next. 

Closed 

The service has removed/deleted much of its internal state and awaits either a 
coldReset or remove transitions. 

Inputs 

An input is the trigger that causes a state transition to occur. In any given state there 
is a defined set of permissible inputs that are available, Le. only those that are 
depicted in the diagram as leaving the current state and connecting with the next 
state. To attempt to perform any other transition is illegal. Note that many inputs 
can have the same name (e.g. error) yet there is no ambiguity as long as the 
originating state is different. 

Clients can provide any input with impunity However a management agent can 
request only provide external inputs. For example the manager might reasonably 
request that a client perform a warm reset, but not to become ready, the client alone 
can provide this input i.e. when it's internal initialization process has completed. 

The available inputs are as follows. 

• start: move into the running state. Start to handle invocations on operational 
interfaces. 

• stop: move into the ready state. Stop handling invocations on operational 
interfaces. 

• ready: move into the ready state having finished initialization. 
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• error: move into the error state, this transition is valid from any state. 

• shutdown: clean up any internal state required and move into the closed state. 
This transition should not cause the deregistering of resources from the 
repository. 

• coldReset: cause a from complete reinitialization of the service and move into 
the initializing state. The only exemption is that resources that are already 
registered should not be reregistered. 

• warmReset: cause a partial reinitialization of the service i.e. retaining some of 
the existing service state move into the initializing state. 

• remove: cause the service to remove itself from existence. Any non-persistent 
resources should be deregistered from the repository. 



Managed Variable Tables 

A managed variable table is at it's simplest a table of name/string value pairs that 
exist within the client but to which a manager has some level of access. Thus a 
management agent can control those aspects of a services behavior that is affected 
by those variables to which it has access. 

There is a degree of configurability associated with managed variables and their 
variables that permit something more sophisticated than the simple get and set 
operations one would expect to find. 

Each table itself has a name to distinguish it from other tables. As we shall see later, 
the managed service model itself provides for two such tables. 

There is a restriction on variable table usage: each name in a variable table must be 
unique within that table. It is not possible to implement lists by having many entries 
with the same name. 
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Configuration Parameter Table 

The configuration parameter table is an instance of a managed variable table with a 
reserved name that identifies it as such. The table holds generic configuration data 
for the client. 

Resource Table 

The resource table is another instance of a managed variable table, identical in 
behavior to the configuration parameter table except that the names in the client's 
table refer to other services with which the client has some relationship. For 
example, if a particular client makes use of a mail service then this relationship can 
be made visible to a management agent through the resource table. Thus a 
management agent might reconfigure the client to use an alternative but equivalent 
service. While there might seem no obvious need to separate out this particular 
aspect of configuration, doing so makes it possible for a management agent to 
discover the topology and integrity of a network of connected services without the 
need for service specific interpretation of the variable table (all entries in the 
resource table are resources). 

The name used for an entry in a resource table can be any symbolic name the client 
chooses, while the value must be the valid e-speak ESName of the actual service. 



Managed Service Interface 

All e-speak Resources that are manageable implement the ManagedService 
interface. This applies whether the Resources are external to the e-speak Core, or 
Core-managed. 

interface ManagedService I ntf { 

String getNameO 

throws ESInvocationException; 

String getDescription ( } 
throws ESInvocationException; 

String getOwner ( ) 
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throws ESInvocationException; 

String getTJptime { ) 

throws ESInvocationException ; 

String getVersionO 

throws ESInvocationException; 

String getErrorCondition ( ) 
throws ESInvocationException; 

String getstaticlnf o () 
throws ESInvocationException; 

void coldReset() 

throws IllegalStateTransition, ESInvocationException; 
void warmResetO 

throws IllegalStateTransition, ESInvocationException; 
void start C ) 

throws IllegalStateTransition, ESInvocationException; 
void stop() 

throws IllegalStateTransition, ESInvocationException; 
void shutdown {) 

throws IllegalStateTransition, ESInvocationException; 
void remove () 

throws IllegalStateTransition, ESInvocationException; 
int getStateO 

throws ESInvocationException; 

VariableEntry [] getVariableEntries ( ) 
throws ESInvocationException; 

String [] getVariableNames ( J 
throws ESInvocationException; 

VariableEntry getVariableEntry (String name) 
throws ESInvocationException, NoSuchVariableName; 

void setVariable (String name, String value) 
throws ESInvocationException; 
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ResourceEntry [] getResourceEntries () 
throws ESInvocationException; 

String [] getResourceNames ( ) 
throws ESInvocationException; 

ResourceEntry get ResourceEntry (String name) 
throws NoSuchVariableName, ESInvocationException; 

void setResource (String name, ESName resource) 

throws ESInvocationException; 

} 

The method getName return String containing the service name. This name should 
be used when registering the service resource in the service vocabulary. 

The method getDescription returns a human readable description of the service for 
display on a management console. 

The method getOwner returns a string indicating the owner of the service. 

The method getUptime gets the time for which the service has been running. The 
format of the string is "years.days.hours.minutes.seconds\ 

The method getVersion returns a string indicating the version of the service. 

The method getErrorCondition returns a string indicating the error condition. This 
returns null if the service is not in an error state. 

The method getStaticInfo returns an XML document of the following form. 
<staticlnf o> 

< name > the name of the resource </name> 

< owner > the name nameof the onwning service </owner> 

<description> the decription here </description> 

<version> the version string </version> 

<uptime> the uptime string </uptime> 

</staticInf o> 

The coldReset transition function cause the service to move into the initializing 
state and completely reinitialize. The exception IllegalStateTransitionException is 
thrown if the state is not in the ready, error or closed states. 
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The warmReset transition function cause the service to move into the initializing 
state and partially reinitialize. The exception IllegalStateTransitionException is 
thrown if the state is not in the ready or error states. 

The start transition function cause the service to move into the running state and 
service client requests. The IllegalStateTransitionException exception is thrown if 
the state is not in the ready state. 

The stop transition function cause the service to move into the ready state and stop 
serving client requests. The exception IllegalStateTransitionException is thrown if 
the state is not in the running state 

The shutdown transition function clean up any internal state required and move 
into the closed state. This transition should not cause the deregistering of resources 
from the repository. The exception IllegalStateTransitionException is thrown, if the 
state is already in the closed state. 

The remove transition function causes the service to remove itself from existence. 
Any non-persistent resources should be deregistered. The exception 
IllegalStateTransitionException is thrown if the state is not in the closed state. 

The method getState return the current state: an integer value from 0 to 4. 

The value returned is interpreted as follows. 

• Initializing (0) - the service is constructing its internal data structures and finding 
other services which is needs to function. 

• Ready (1) - the service is fully constructed and ready to run. 

• Running (2) - the service is running and handling methods on its operational 
interfaces. 

• Closed (3) - the service has deleted much of its internal state and closed any open 
connections to files or other services. 

• Error (4) - The service has encountered an error preventing the service from 
continuing to operate. 
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The Variable Table 

Each manageable Resource maintains a table of name value pairs, which contains 
whatever information that Resource wishes to expose to the management agent. 
The table entries can be either read only or read write. 

class VariableEntry { 
String name; 
String value; 
int updateType; 
} 

The method getVariableEntries returns the table as an array of VariableEntry's. 
Each VariableEntry object contains the name, the value & update information. 

The method getVariableNames returns an array of strings - one element in the array 
for each variable. 

The method getVariableEntry returns the entry in the table for variable identified in 
the parameter name. 

The method setVariable sets the variable identified by the parameter name to the 
string in the value parameter. 

The Resource Table 

The managed Resource maintains a table of name-Resource pairs. This table 
contains all the Resources that the element depends on i.e. uses. The table entries 
can be either read only or read write. 

class ResourceEntry { 
String name; 
ESName resource; 
int updateType; 
} 

The method getResourceEntries returns the table as an array of ResourceEntry. 
Each entry contains a string that name for the resource, the ESName of the resource 
(URL) and the update information. 

The method getResourceNames returns an array of strings, one element for each 
entry in the resource table. 
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The method getResourceEntry (String name) returns the entry in the table for the 
named resource. 

The method setResource sets the Resource identified by the name parameter to the 
ESName supplied in the resource parameter. 
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The Repository is not part of the e-speak architecture because Clients have no 
direct interaction with it. However, understanding the operation of the Repository 
helps in understanding other parts of the architecture. Also, the behavior of the 
system depends on how the Repository is configured. This chapter describes the 
reference implementation, the Core-Repository interfaces for including 
Repositories of different internal structures, and various scalability issues. 



Repository Overview 

The Repository holds the data needed by the Core. This data includes the Resource 
metadata as well as the internal state of Core-managed Resources. The Repository 
is also read by the Lookup Service when a Client requests a lookup. These two 
operations have different design points. Access to metadata and Core-managed 
Resources is done frequently and needs to be low latency. Lookup requests are akin 
to database queries; they are less latency sensitive but must be completed relatively 
quickly. 



Repository Structure 

To support the conflicting goals of flexible query lookup on a large persistent set 
and rapid access to a smaller, transient subset, the reference implementation of the 
Repository described here is divided into two components: the Repository 
Database and the Repository Access Table, 
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The Repository Database provides persistent storage and efficient lookup request 
processing. This component is left parameterized in the Core-Repository interface. 
All that is needed is an appropriate database interface. This design allows different 
implementations of the Repository to select the most appropriate database based 
on relevant business and technical considerations. 

A very broad range of persistent repository implementation is allowed. This 
Repository Database interface gives another architectural degree of freedom. For 
instance, in the case of a battery-backed RAM device or in situations where 
persistence is simply not a requirement, a pure RAM-based Repository Database 
implementation is feasible. Thus, the Repository Database need not have a large 
footprint. 

The second component the Repository Access Table, is fully resident in memory in 
the reference implementation. This access table is rebuilt from data in the 
Repository Database as part of a system restart. The access table supports a fast 
associative lookup of information based on Repository Handles. It can be a cache 
of the Repository data, or it might be large enough to hold all the data needed for 
Resource access. 



Information Flow 

Every e-speak installation comes with an in-memory Repository that does not 
support persistence. To add the feature of scalability, a gJuelayer must be provided 
to convert Core requests to the Repository into meaningful requests to the selected 
implementation. This glue layer must implement the information flow methods 
described in this section. In addition, the glue layer can also include interfaces 
specific to the selected Repository implementation, such as setting controls. 

The Repository Database has two interfaces used by the Core. The Core-Repository 
interfaces have methods to: 

• Register and unregister Resources 

• Access the metadata corresponding to a given Repository Handle 

• Modify the metadata corresponding to a given Repository Handle 
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• Look up Resources that match a Search Recipe 

The Client can access these methods only indirectly by invoking methods in the 
Contract, Name Frame, and MetaResource. The following illustrate the methods 
that need to be supported in these interfaces. The exact signatures and functions 
vary from implementation to implementation. In the current implementation these 
interfaces can be found in netespeakinfra.core.repository .Repository 

public RepositoryHandle registerDescription ( 

String name, 

ResourceDescription d, 

ResourceSpecif ication s) 

throws InvalidSpecif icationException; 

public void unregisterDescription ( 
RepositoryHandle handle) 
throws StaleHandleException ; 

public ResourceDescription accessDescription ( 
RepositoryHandle handle) 
throws StaleHandleException; 

public ResourceSpecif ication accessSpec ( 
RepositoryHandle handle) 
throws StaleHandleException; 

public RepositoryHandle mutateDescription ( 
Repos i t oryHandl e hand 1 e , 

ResourceDescription d, 
ResourceSpecif ication s) 
throws StaleHandleException; 

The second interface is presented to the Core by the Repository to invoke the 
Lookup Service for a Repository lookup request. This interface is invoked when the 
Client does a lookup in a Name Frame: 

public RepositoryHandle!] find (SearchRecipe recipe) 
throws Inval idSearchRe quest Except ion; 

The Repository can access permanent storage, but the protocol used for such 
access is not part of thee-speak architecture. 
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Increasing Scalability 

Because a Resource can be used only if it has been registered in the local 
Repository, it is important to consider the eventuality of a full Repository. Two 
kinds of e-speak Repositories are based on deployment needs: a thin Repository 
and a fat Repository. 

A thin Repository does not have enough disk space to grow with the number of 
Repository entries. Its purpose is to support Repository Handle-based access, with 
latency on the order of microseconds. This support is provided on a smaller, 
transient, subset of Repository entries, which corresponds to M in-use" Resources. A 
thin Repository is very sensitive to stale data; it must enforce strong policies to: 

• Dispose of stale entries, and 

• Prevent marginally accessed entries from accumulating. 

A thin Repository can have no persistent storage of its own. Thus, because the 
number of Repository entries that can be stored in a thin Repository is small, an 
xn-jnernorKRepository implementation is appropriate. 

A fat Repository has a lot of disk space and can act as a server to a thin Repository. 
Clearly, such a Repository can be highly available. The primary purpose of such a 
Repository is to support Resource lookup requests with "reasonable" latency (on 
the order of milliseconds). A fat Repository is not very sensitive to stale data. 
Because the number of Repository entries that can be stored in a fat Repository is 
very large, Repository implementation based on a database is appropriate. 

A thin Repository can use a fat Repository to fulfill its scalability needs, and a fat 
Repository can simultaneously serve many thin Repositories. However, many 
devices cannot need such support because their transient state can hold all the 
information necessary. 

The communication between a fat Repository that provides services to a thin 
Repository is not part of the e-speak architecture. However, because the security of 
the system depends on the integrity of this communication, the link must be 
protected. It is the security of the communication link that makes the Repository 
part of the Core, irrespective of the physical machine that holds the Repository. 
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The keylndexType field: Efficient Repository Lookup 

In DBMS, indexes are the primary means of reducing the volume of data that must 
be fetched and processed in response to a query. If there were no indexes used for 
resource description attributes in an e-speak repository, every resource defined 
against a particular vocabulary needs to be examined to see if it matches the 
constraints specified in the search recipe. This would cause very slow performance 
on lookups when large numbers of resources are registered in the e-speak Core. So 
there needs to be a way of specifying which attributes properties within a 
Vocabulary are the 'key' attributes so that some indexing scheme can be added. 

It is not reasonable to index each and every attribute in a resource description. The 
more indexes that you have, the more overhead in registering descriptions and also 
the memory requirement becomes more for in-memory repository. It does not make 
sense to index attributes that are not going to be frequently used in constraints. 
Therefore, there needs to be a way of specifying which attribute properties within 
a vocabulary are the 'key* attributes so that some indexing scheme can be 
implemented on these 'key* attribute properties. 

This is the purpose of the keylndexType field in AttributeProperty (xref to core 
managed resource Vocabulary section). Valid values of keylndexType are: 
NOJNDEX, HASHJNDEX and TREEJNDEX. If the value is HASHJNDEX or 
TREE JNDEX the attribute is used as an index by the DBMS. 
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A key factor in global acceptance of a software package is its ability to be 
customized to the location running the software. It is very frustrating for a user to 
have to read messages in a language other than their own native language or 
interpret numbers using a foreign format. Imagine if you had to understand an error 
message written in German, or recognized that the string * 06/01/99" really means 
January 6th and not June 1st. 

This chapter describes how to support localizing e-speak for native language and 
locale-dependent number & date formats. This design is implemented in the current 
release of e-speak. However, currently all entities have the same underlying data 
catalog to get their localized strings. 



Current Implementation 

The current code has hard-coded strings for all display messages and exception 
details. It also hard-codes the format of number and date/time representations. 

For example: 

• net.espeak.infra.core.startup.StartESCore prints a message when the core is 
initialized using System.outprintC Starting ES Core Server with Rendezvous of 
r + popURL + T. "); and System.outprintlnC started.");. 

• Value.getStringO simply calls the toString method of the data type object 
represented by the Value class. 
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String Messages 

There are three requirements for string messages: 

• A framework implementation which supports the use of localized string 
messages. 

• A English implementation of all string messages within the core, cci and client 
packages, using the framework created above. 

• Additional language implementations as required by our customers. 

Framework 

• Any time the message text is moved away from the code that produces the 
message, confusion and incorrect messaging is likely. It is important therefore, 
that the framework minimized the confusion and makes it difficult to issue the 
incorrect message. A hierarchical structure must be supported for the 
specification of the message to be issued. 

• Messages are rarely static, Le., they often contain concatenations of variable 
values in the middle of the message. The framework must support the 
substitution of variable values in the body of the message. 

• The framework must support the specification of the location and language of 
the user. If support for the requested location and language are not 
implemented, the framework should provide the closest match to the requested 
location and language available. 

• A likely scenario includes the core running in one locale and the client running 
in a different locale. The framework must support a core issuing a message in 
the client's locale language. 

• During development phases, the framework should throw exceptions if the 
invocation of the messaging methods are coded incorrectly (e.g., a message id 
that is not valid), but in the release the framework should make a best attempt 
to format the message for the user. 
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• The framework must be initialized during the startup of the e-speak processes. 

English implementation 

1 The current code base must be examined for each string message that is 
produced. Unless there is a good reason for keeping the message definition local 
(e.g., a debug message), the text of the message should be placed in the English 
string implementation file and the reference changed to retrieve the message 
text. 

2 This English implementation becomes the base implementation and is shown to 
the user as the default language if their specified language is not implemented. 

Additional language implementations 

• After a good English implementation has been developed additional language 
implementations can be created translating the message text from English to the 
new language. 

• After an additional language is created, changes to existing messages must also 
be changed in each of the additional languages. This is a development process 
issue that is addressed further here. 

• If a new message is created in the base implementation (English) , the new 
message does not need to be implemented in all other languages, however, if this 
is the case the user sees the English version of the message. 



Number & 



Date Formats 



The requirements for non-string formats is broken into two categories: 

• Vocabulary attributes 

* Value class string representations 
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Vocabulary Attributes 

Three new data types should be supported which provide for locale-defined 
formats. They are: 

• Decimal: This data type provides for a decimal representation of a number in a 
user-defined pattern. The pattern can be derived from the locale-defined format 
or customized by the user. For example: Decimal number = new 
DecimalC###,###J# w ); 

• Currency: This data type provides a specialized Decimal format that includes the 
currency symbol and format defined by the user s locale. 

• Per: This data type provides a specialized Decimal format for percentages using 
the symbols and format defined by the user s locale. 

Value class string representations 

The Value class getString method should return a string representation that is 
customized by the users locale formats. Specifically: 

Ttmestamp Date 

Time Decimal 

Currency Percent 
Numeric data type (Long, Double, Float, etc.) 



High-level Design 

The implementation for the Number and Date formats are left to the Vocabulary 
team. This document only addresses the String Message requirements. Shown 
below is the class diagram for the classes implementing localization. 
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ES String 

messageID:Stnng 

infoiObjectfl 

ESStringQ 
ESStnng( String) 
ESString( String, Object) 
ESString( String int) 
ESString( String, Object, Object) 
ESString( String Object[D 
toString():String 

receiveObject(MessagelnputStxeam):Object 
sendObject( MessageOutputStream):votd 



ESStrings 

table:ESMap 

contentsDbjectnn 

ge tKeys() :Enuitieration 
handleGetObject( String):Object 



ESText 

myResources:ResourceBundle 
myCustomResources;ESList 

throwExceptionsiboolean 

initialize( String):void 
throwExceptions():boolean 
setThiowExceptions( b o dean) :void 
getLocaleString( Object) :Stiing 
getM e ss age( String) :String 
getMessage( String, Object):String 
getM ess age( String, Object* Object):String 
getMessage( String, Object|]):String 
findMe ssage( String):String 
isDigtt( String):booiean 



ESText, ESStrings & ESString classes 

Three new classes are defined. ESText is the retrieval class and ESStrings is the 
language dependent implementation class. ESString is a logical extension to String 
which performs the localization at the last possible moment (client in most cases). 

The unitize 0 method needs to be called by each process that uses the ESText 
facility. If this method is not called, the first invocation of getMessage defaults to 
the e-speak base class. The unitize method uses the java.util.ResourceBundle class 
to discover the language defined strings. ESText supports multiple base classes. 
After it is unitized, it can be called multiple times with different base class name 
parameters. When ESText looks up a message, it searches all the supplied base 
classes to resolve the message ID. 

The throwExceptions and setThrowException methods return and specify if 
exceptions are thrown for detected problems (see below). 
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Additional getMessage prototypes can be created with multiple params if the need 
arises. 

The base implementation for ESStrings looks like the following: 

public class ESStrings extends ListResourceBundle 
{ 

public Object [] [] getContents ( ) { 
return contents; 

} 

static final Object [] [] contents = { 

{ u net .espeak, startup .Hello" , "template for 1D1"}, 

{ "net. espeak.es lib. ESFolder. dup" , "template for ID2"} 



Each additional language looks like the following; 

public class ESStrings de extends ListResourceBundle 

{ 

public Object [] [] getContents () { 
return contents; 

} 

static final Object [] [] contents = { 
{ u net . espeak . startup . Hello" , 
w German override for ID1" } , 
{ "net . espeak , eslib . ESFolder . dup" , 
* German override for ID2" } 

} ^ 

Class names are searched in the following order: 

1 baseclass + * J* + language + "J* + country + *_* + variant 

2 baseclass + 4- language + * + country 

3 baseclass + + language 

4 baseclass 

ResourceBundle automatically defers to this search order for any message ID that 
is not found in the specific language implementation or if the specific language 
implementation is missing. 

The optional param values are substituted in the message text by the following 
rules: 
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• For each occurrence of the string " %n" , the string is replaced by the 
object [n].toStringO value. Note that this is a zero-based index. 

• If "n" is out of bounds for the supplied params, the string "n/a" should be 
substituted. Note: during development, this situation threw an exception. 

• If a param is not referenced by the message, the param should be ignored. Note: 
during development this situation is thrown an exception. 

• Multiple references to the same param should be valid (e.g., "%0 blah %0") . 

• If the included object is a localizable object (Timestamp, Date, Time or Number) 
the locale-defined formatting rules are applied to this object. 

• To code a percent sign in the message, code two percent signs (%%). 

• To include all passed parameters, code " %a!F in the message template. This is be 
replaced by [argO, argl, ...]. 

The last class is ESString. This class logically extends the java.lang.String class for 
localization. It accepts a message ID and optional data objects in the same way as 
ESText does. The toString method localizes the message when it is called rather 
than when it is constructed. 



Below is an example of how the StartESCore message can be coded. The 
ESStrings.java class contains the following: 

public class ESStrings extends ListResourceBundle 



static final Object [] [] contents = { 
{ n es . core . startup .Hellol" , 
"Starting ES Core Server with * + 
"Rendezvous of \"%0\" ..."}, 
{ n es . core . startup ,Hello2" , n started."} 



Usage example 



public Object [][] getContents ( ) { 
return contents; 



The StartESCore.java class contains the following: 
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System. out .print {ESText .getMessage ( 

tt es . core . startup .Hellol" , popURL) ) ; 
System. out . print In (ESText . getMessage ( 

"es. core. startup. Hello2") ) ; 

The ESString class is used as follows: 

throw new StaleEntryAccessException ( 

new ESString ( M es. core. startup. Hello2") ) ; 

Additional design considerations 
ID specifications 

To simplify the ID generation and reduce the chances of duplications, the IDs 
should follow the following convention: 

• Use the dot format to specify the hierarchy. For example, message IDs for the 
StartESCore class should be "es.core.startup.StartESCore.*". 

• The last node should be a short description string denoting the message. For 
example, the startup message issued today by StartESCore would have the ID of 
u es.core.starStartESCore.HeHo* . 

• Messages are defined in the ESStrings class in sorted ID order. 
Core generated exceptions 

Because it is possible that the core is running in a different locale from the client, 
any message text produced in the core that is destined for a client should be 
specified in the client language. To do this, modify the exception classes to pass the 
additional objects instead of the text. The exception.getMessage code on the client 
side uses the ESText class to map the exception number to a message ID and 
performs the substitutions in the client s language. 

Client usage 

Client applications can use these classes as well. They need only call 
ESText initialize 0 with the base class name for their ESStrings equivalent. 
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ESString Wire Format 

class ESString{ 
String messagelD; 
Object!] info; 
} 

The message ID specifies the text of the message in either the service-defined 
message catalog or the e-speak defined catalog. The message ID is used to retrieve 
a message template from the catalog (ESStrings). The optional Objects are 
substituted into the message based upon the syntax of the message template. 

Message templates can contain the M %" (percent sign) symbol followed by a number. 
The number the index info object The percent sign (and the number following it) 
are substituted with the toString value of the associated object. 

An example entry from the current e-speak message catalog 
(net. espeak.util.ESStrings) 

MessagelD : "net . espeak . exception . 4 " 

Message template: "Parameter 1 %0' invalid type, expected 1 %l ,n 
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The next release of e-speak will integrate the current e-speak Core with the Web 
Access architecture (see e-speak Web Access Architecture). It will also implement 
the localization architecture described in Chapter 11, "Localization". 
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Glossary 



This chapter needs check to make sure we are not using terms no longer needed. 
Terms to do with security (keys and locks) need to be removed. New terms need to 
be added: certificate, key, PKI, ACI, Principal, URL, ESPDU probably others. 



Term 



Meaning 



Advertising Service 



A service for looking up resources not registered in the tocai 
Repository. It returns zero or more Connection Objects. 



Arbitration policy 



A specification within the search request accessor for naming 
that provides the logic to resolve multiple matches found for 
a name search. 



Attribute 
Vocabulary 



See Vocabulary. 



Base Vocabulary A Vocabulary provided at system start-up. 



Builder 



An entity identified by a Remote Resource Handler that is 
used to construct the internal state of a Resource imported 
by value. 



Certificate 



A data structure assigning a Tag or name to a Subject. 
Certificates are signed using cryptographic techniques so 
they cannot be tampered with. 
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Meaning 



Certificate Issuer 
(CI)) 

Client 



A service issuing certificates to Subjects. 



Any active entity (e.g., a process, thread, service provider) 
that uses the e-speak infrastructure to process a request for 
a Resource. 



Client library The interface specification that defines the interface for 

e-speak programmers and system developers that will build 
e-speak-enabied applications. 



Connection 
Manager 



A Logical Machine's component that does the initial 
connection with another Logical Machine, 



Contract 



See Resource Contract. 



Core 



The active entity of a Logical Machine that mediates access 
to Resources registered in the local Repository. 



Core Event 
Distributor 



A Core-managed Resource whose purpose is to collect 
information on e-speak Events and make such information 
available to management tools within the infrastructures. 



Core-managed 
Resource 



A Resource with an internal state managed by the Core. 



Distributor Service A service that forwards published Events to subscribers. 



Event 



A message that results in the recipient invoking a registered 
callback. 
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Term 



A/leaning 



Event filter 



A subscription specification expressed as a set of attributes 
in a particular Vocabulary that must match those in the Event 
state in order for a Client to receive notification on publication 
of an Event. 



Event state 



A reference within an Event to its expressed set of attributes 
in a particular Vocabulary. These attributes must match the 
Event filter in order for the subscriber to receive notification 
of the Event. 



Explicit Binding An accessor that contains a Repository Handle. 



import Name 
Frame 



A container that holds a name for each imported Resource. 



Inbox 



A Core-managed Resource used to hold request messages 
from the Core to a Client. 



Issuer 



An entity issuing a certificate. The Issuer is denoted in a 
certificate by its Public Key 



Logical Machine A Core and its Repository. 



Lookup request 



Resources with attributes matching the lookup request will 
be bound to a name in the Client's name space. 



Lookup Service 



The component that performs lookup requests used to find 
Resources that match attribute-value pairs in the Resource 
Description of Resources registered in the Repository. 



Mailbox 



Either an Outbox or an Inbox. 
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Term 



Meaning 



Mapping Object An object binding an ESName to Resources or a Search 
Recipe. 



Message 
Metadata 



Means of Client-Core communication. 

Data that is not part of the Resource's implementation, but is 
used to describe and protect the Resource. 



Name Frame A Core-managed Resource that associates a string with a 

Mapping Object. 

Name Search A name conflict resolution tool used by the Core to find the 

Policy appropriate strings when looking up names in a Name Frame. 



Outbox 



The location where the Client places a message to request 
access to a Resource. 



Pass-by value A metadata field, which, when set to true, includes the state 

of the Resource in the Export Form. 



Principal 



The entity holding the Private Key corresponding to a given 
Public Key 



Private Key 



This is secret data. An entity demonstrates knowledge of this 
secrete data by cryptographic techniques to authenticate 
itself. Private Keys must be kept secret 



Private Security A cryptographically secure store for Private Keys. 
Environment (PSE) 
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Term 



Meaning 



Protection Domain 



The environment associated with a particular Outbox from 
which Resources can be accessed. 



Publish 



A request sent to the Distributor Service to publish Events. 



Public Key 



Non-secret data that is associated with a given Private Key by 
cryptographic techniques 



Public Key A set of services and protocols that support the use of public 

Infrastructure (PKI) and private key pairs by applications for security. 



Repository 



A passive entity in the Core that stores Resource metadata 
and the internal state of Core-managed Resources. 



Repository entry 



The metadata of a Resource as stored in the Repository and 
made available to the Core when a Client's requests to 
access Resources are processed. 



Repository Handle An index into the Repository associated with the metadata of 
a Resource. 



Repository View 



A Resource that can be used to limit the search for particular 
Resources in a large Resource Repository, much as a 
database view restricts a search within a database. 



Resource Contract 



A Resource denoting an agreement between the Client and 
the Resource Handler for use of a particular Resource. The 
agreement includes a provision for the Client to use an API 
known to the Resource Handler when making the request for 
the Resource. 
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Term 



Meaning 



Resource 



Resource 
Description 



Resource Factory 



Resource Handler 



Resource Specific 
Data 

Resource 
Specification 

Session Layer 
Security Protocol 
(SLS) 

Service Identity 
(ServicelD) 

Simple Public Key 

Infrastructure 

(SPKI) 

State 



The fundamental abstraction in e-speak. Consists of state and 
metadata. 

The data specified for the Attribute field of the metadata as 
represented by the Client to the Core. See also Resource 
Specification. 

An entity that can build the internai state of a Resource 
requested by a Client. 

A Client responsible for responding to requests for access to 
one or more Resources. 

A metadata field of a Resource. Carries information about the 
Resource. Can be public or private to the Resource Handler. 

Consists of all metadata fields, except the Attributes field, as 
represented by the Client to the Core. 

The low level message protocol used by all e-speak Cores 
and Clients for remote communication. 



A field in the metadata that identifies a service or Resource 



A specific variant of PKI developed within the Internet 
Engineering Task Force and used by e-speak. 



Data a Resource needs to implement its abstraction. 
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Term 



Meaning 



Subject The entity to which the access right or name has been issued. 

In a certificate the Subject is denoted by its Public Key. 

Vocabulary A Resource that contains the set of attributes and value types 

for describing Resources. 

Tag The field in a certificate expressing an access right 

Vocabulary Builder A Core-managed Resource registered by the Lookup Service 
that is used to create new value types, attributes, and 
Vocabularies. 

Vocabulary A reference to a mechanism that is used to provide 

Translator interoperation between different Vocabularies by mapping 

attributes from one Vocabulary into another through a 

Translator Resource. 
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License Agreement 

This license is reproduced from the license that you must agree to when the software is 
installed; 

ATTENTION: USE OF THE SOFTWARE IS SUBJECT TO THE HP SOFTWARE LICENSE 
TERMS SET FORTH BELOW. USING THE SOFTWARE INDICATES YOUR ACCEPTANCE 
OF THESE LICENSE TERMS. IF YOU DO NOT ACCEPT THESE LICENSE TERMS YOU 
MAY RETURN THE SOFTWARE FOR A FULL REFUND. IF THE SOFTWARE IS BUNDLED 
WITH ANOTHER PRODUCT, YOU MAY RETURN THE ENTIRE UNUSED PRODUCT FOR A 
FULL REFUND. 

HP SOFTWARE LICENSE TERMS 

The following License Terms govern your use of the accompanying Software unless you have 
a separate signed agreement with HP. 

License Grant, In return for payment of the applicable fee, HP grants you a license to use 
one copy of the Software. "Use" means storing, loading, installing, executing or displaying the 
Software. You may not modify the Software or disable any licensing or control features of the 
Software. If the Software is licensed for "concurrent use", you may not allow more than the 
maximum number of authorized users to Use the Software concurrently. 

Ownership. The Software is owned and copyrighted by HP or its third parry suppliers. Your 
license confers no title to, or ownership in, the Software and is not a sale of any rights in the 
Software. HP's third party suppliers may protect their rights in the event of any violation of 
these License Terms. 

Copies and Adaptations. You may only make copies or adaptations of the Software for 
archival purposes or when copying or adaptation is an essential step in the authorized Use of 
the Software. You must reproduce all copyright notices in the original Software on all copies 
or adaptations. You may not copy the Software onto any public network. 

No Disassembly or Decryption. You may not disassemble or decompile the Software 
unless HP's prior written consent is obtained. In some jurisdictions, HP's consent may not be 
required for limited disassembly or decompilation. Upon request, you will provide HP with 
reasonably detailed information regarding any disassembly or decompilation. You may not 
decrypt the Software unless decryption is a necessary part of the operation of the Software. 

Transfer. Your license will automatically terminate upon any transfer of the Software Upon 
transfer, you must deliver the Software, including any copies and related documentation, to 
the transferee. The transferee must accept these License Terms as a condition to the transfer. 

Termination. HP may terminate your license upon notice for failure to comply with any of 
these License Terms. Upon termination, you must immediately destroy the Software, 
together with all copies, adaptations and merged portions in any form. 
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Export Requirements. You may not export or re-export the Software or any copy or 
adaptation in violation of any applicable laws or regulations. 

U.S. Government Restricted Rights. The Software and any accompanying documentation 
have been developed entirely at private expense. They are delivered and licensed as 
"commercial computer software" as defined in DFARS 252.227-7013 (Oct 1988), DFARS 
252.211-7015 (May 1991) or DFARS 252.227-7014 (Jun 1995), as a "commercial item" as 
defined in FAR 2.101 (a), or as "Restricted computer software" as defined in FAR 52.227-19 
(Jun 1987) (or any equivalent agency regulation or contract clause), whichever is applicable. 
You have only those rights provided for such Software and any accompanying 
documentation by the applicable FAR or DFARS clause or the HP standard software 
agreement for the product involved. 
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Buying a VCR with E-speak 

Let's suppose we want to buy a new VCR. 

Now, lets look at the differences we would find if we were to try to buy that VCR in 
a large department store and in a large shopping mall 

The Department store has a known location. It also has known products. 

The products in the department store are generally of the same brand. In addition, 
these products are generally going to have known qualities, such as price, style and 
color. If we were looking for an odd color, we probably wouldn't find it. The price 
is fixed and even though several similar products might be found in slightly different 
price ranges, the ranges are limited. 

These product attributes (price, color and style) are non varying and that is 
extremely helpful for the store in deciding what items to stock. 

Unfortunately for the Client that needs to use the store's Service, it may not be 
possible to find the right combination of attributes to meet their requirements. 

Next month, if we need a VCR with a different set of attributes, say a different 
brankd in a different color, and we return to the same location and the store has 
closed, it is a huge inconvenience. Having never anticipated that the store might 
suddenly go 'off line', we are now forced to stop what we are doing and search for 
a new store. 

Now let s go to the mall. 

The first thing we do is to drop by the Directory Board at the entrance to discover 
which stores have advertised their ability to sell VCRs. 
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Armed with this information, we visit each store with our list of required attributes 
for the VCR we want, to see if they can match the price, feature set and style that 
we have in mind. 

Several of these stores may meet our criteria. In that case we can further refine our 
decision making process by prioritizing our request. We may decide to make a list 
with price as the governing item. 

If we return next month with a requirement for a VCR with different attributes, we 
still make our first stop at the Directory Board. If any of the stores that we shopped 
at on the last visit are off line or new ones have been added, it doesn't affect our 
process of buying a VCR. 

After discovering the Services that sell VCRs, we make the rounds inquiring about 
the attribute list (color, price, style) that each sell, and since our list of stores is up 
to date, we automatically include new stores that have come on line, and do not 
bother wasting our time making inquires of stores that have closed. 

If a store has changed or reconfigured the attributes of their services, (say they no 
longer offer the VCR in a brand compatable with the rest of our equipment) we will 
find this out during our initial inquiry and they will be filtered out from our final 
decision making process. 

Doing this discovery and inquiry process every time, may seem like an arduous task, 
and indeed it is when we walk around the mall and do it. Fortunately for us, in the 
electronic world, these are the kind of repetitive jobs computers love to do. 

As you have probably guessed by now, E-speak is built along the lines of the 
shopping mall paradigm. 

It s job, like that of a mall, is to connect Services with Clients. 

Services may come and go, so they need to be Dynamically Discoverable and E- 
speak provides for this. 

The attributes (or what a service offers) may change also, so Services need to be 
Dynamical ly Configurable , and E-speak provides for this too. 
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E-speak does this by supporting a set of characteristics for its Services which allow 
Clients to Discover and use them. 



Service 
Characteristic 


Function 


Description 


Enables a Service to be Discovered 


Interface 


Allows Clients to communicate with Services 


Mediating Access 


Allows Services to coexist with other Services 



Table 1 - Characteristics of E-speak Services 



The way E-speak allows all this dynamic interaction is by separating the different 
roles played by the various members in an E-speak community. 

The entities involved in defining Service ecosystems are categorized as follows 

The roles and Jobs of the members of the E-speak community are: 



Role 


Job 


Service Developers 


Create new Services 


Service Standards Bodies 


Define new services 


Service Deploy ers 


Advertise the services 


Service Directories 


Provide locations where services are advertised 


Service administrators 


Monitor and Control Services 



Table 2 - Roles and Characteristics of E-speak Components 
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Functions and Roles of E-speak Entities 

• Service developers who create new Services 

• Service standards bodies who define new services 

• Service deployers who advertise the services 

• Service Directories which are locations where services are advertise 

• Service administrators who monitor and control services. 

• Service developers: These are the developers of the actual Service 
implementation. Service developers design their Service to comply with the 
programmatic Service interfaces published by the standards bodies. Service 
developers are also able to wrap existing legacy applications so that they can be 
made available as services in the e-speak infrastructure. 

* Service standards bodies: Standardization bodies define and publish 
standardized interfaces for different Service categories that are used by Service 
developers to write Services conforming to the standardized interface. 

For example, a standards body may define a generic printer Service interface to 
contain the following invocation points: printQf and statusO- Any Service 
provider interested in providing a printer Service writes their Service to support 
this interface. 

In addition, the standardization body is responsible for identifying the Vocabu- 
lary-used to describe a Service. The Vocabulary describes the attributes that are 
used to uniquely describe a Service. For example, a printer Vocabulary includes 
attributes such as Manufacturer, Modelname, DPI and so on (perhaps using 
XML) that is used by service deployers to advertise this Service, and queried by 
Clients to discover it. 

• Service deployers: Service deployers are responsible for deploying the 
Services created by the Service developers. They are responsible for advertising 
the Services in the appropriate Vocabulary and also for handling requests to the 
Service. 

♦ Service administrators: These administrators are responsible for monitoring, 
administering, and controlling the Service deployment. 
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♦ Service Directories: These directories are places where service providers and 
clients can advertise and find other services that are of interest to them. 

Segregation of Services 

This segregation of roles allows the Service developers to concentrate on the 
business logic of the Service that they are developing, the Service deployers to 
concentrate on advertising and handling requests to the Service, and the 
administrators to administer the Service. Furthermore, the existence of service 
directories greatly simplifies the process of building new composite services by 
providing a place where services can find other services. An example of such a 
service directory is accessible from the E-speak.hp.com site that each E-speak 
installation points to by default. 

All the above entities get their work done by communication with the e-speak Core. 
The Core is the active entity of e-speak that acts as the mediation layer and routes 
messages to Services. 

Figure 1 shows a typical interaction between Clients and Service providers in an 
e-speak community. 

An e-speak community consists of a number of Cores connected to each other. 
Clients and Service providers join the community through these Cores. 

Clients search for Services registered in the community , and when they are 
successful, they gain access to the Service using a Service proxy (stub) of the 
discovered Service. 

The Clients need to know only the interface of the Service in order to invoke object- 
oriented functions (methods) on it. 



Developer Release X.03.03.00, September 2000 



5 



Buying a VCR with E-speak 



Introduction 




Figure 1 Typical interaction between Clients and Service providers 

All access to e-speak go through the E-speak core, unlike other strategies where 
only discovery is done through an infrastructure and communications thereafter 
takes place directly between servers and clients. 

The advantages of this are improved: 

• Security mechanisms 

• Accounting 

• Auditing 

• Billing. 
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Programming Model 

The primary goal of E-speak is to simplify the development, deployment, and 
management of communities of Services on the Internet. 

To accomplish this, E-speak provides three basic abstractions: 

• Services 

• Service Contracts 

• Service Vocabularies 

NOTE: All three of these abstractions are first class entities in E-Speak 

E-speak Services 

Essentially, Services are programs written in a programming language such as Java, 
C, Perl, and C-i-k 

Figure 2 illustrates the relationship between Services, their Contracts, and their 
Vocabularies. 
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Figure 2 Relationships among Services, Contracts, and Vocabularies 

NOTE: E-speak Services conform to their Contracts because by design, they 
implement the interfaces outlined in their Contract 

All services are advertised in appropriate Vocabularies. 

Service Vocabularies essentially provide the scheme for constructing the 
description of the Service. 

By decoupling Services from the Contract and the Vocabulary, E-speak allows 
Service implementors (the developers) to be independent of Service Deploy ers (the 
Advertisers). 
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This decoupling is a fundamental part of E-speak. 

NOTE: Clients are not dependent on the Service developer and deployer to 
communicate the Service Contracts and Vocabularies with which these 
Services have been described. 

The mechanism by which this happens proceeds as follows: 

1 The Service Deployers register their Services with a group of E-speak Cores. On 
registering a Service, this Service is discoverable by others in the same E-speak 
group of Cores. 

2 Clients use the default E-speak finders provided or write their own finders to 
find Services that meet their requirements. 

3 The access permissions of the Service determine the Services that will be visible 
to the Clients. 

4 On finding Services, Clients receive a remote stub to the Service. 

Service Contracts 

Each E-speak Service implements a set of interfaces defined in a Service Contract. 

Service Contracts are first-class entities that can be discovered and used like any 
other Service. All Service Contracts support a base set of interfaces that provide 
mechanisms to create and query them. 

For this reason, Contracts also can be advertised in a well-known Vocabulary — 
typically by a Standardization Body. 

This ability to standardize Vocabularies into allows finding Services and 
communicating with the to proceed smoothly in E-speak, especially give the highly 
dynamic nature of clients and services on the web. This is the reason E-speak was 
designed the way it was 
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Service Vocabularies 

A Vocabulary consists of a set of associated attributes and properties. The only 
properties associated with any attribute are: 

• Name of the attribute 

• Type of values allowed 

NOTE: The structure of a Vocabulary is dependent on the vertical market 
for which it is defined. 

For example, the Vocabulary used to define a printer with attributes such as 
manufacturer, model name, DPI, speed, color, and cost is quite different from the 
Vocabulary that defines apparel merchandise that has attributes such as size, color, 
material, and cost. 

Caution: Though some of the attribute names may be the same across Vocabular- 
ies, they may have different semantics. 

The attribute color in the Printer Vocabulary may be a boolean expression that 
indicates whether the printer supports color printing; however, the attribute color 
in the Apparel Vocabulary may indicate the actual color of the piece of clothing. 

Because Vocabularies are first-class entities, Clients and Services alike can find 
these Vocabularies registered in the community and subsequently make use of 
them. New Vocabularies are typically advertised using the Base Vocabulary that is 
available in the e-speak infrastructure. 

This Base Vocabulary defines a set of attributes that are generic and can be used by 
generic Services in markets that do not have well-defined Vocabularies. All Services 
registered as a Vocabulary conform to the Vocabulary Contract that defines the 
operations that can legally be performed on Vocabularies. 

E-speak System Services 

In addition to the base abstractions of Vocabulary, Contracts, and Services, E-Speak 
supports a set of base and extended services that makes the job of deploying and 
using Internet-wide Services simple. 
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Basic Services 

These are the basic set of Services that are required to get connected to the e-speak 
infrastructure and to create and find new user-defined Services. These Services 
include the following: 

• Connection — A connection Service is used to connect and disconnect from the 
e-speak infrastructure. 

• Vocabulary — A Vocabulary Service allows the creation of new Vocabularies 
and queries the properties of existing Vocabularies. 

• Contract — The Contract Service is used to create and use Contracts. 

• Elements and Finders — Service elements are used to register Services with 
the Core, while Service finders are used to find Services. 

Extended Services 

• Events — This Service defines a distributed Event Publisher-Subscriber model 
for Events. Events are distributed by a Distributor across any number of 
connected Cores. 

• Community — This Service enables discovery of Services across multiple 
e-speak cores. Communities are Client-side abstractions of collections of groups 
that form the search domain. The Community is a collection of member core 
groups identified by group names. 

• Folders — The Folder Service allows users to manage their Services (discovered 
or created) similar to how they manage local files in a standard operating 
system. Persistent folders appear on reconnecting and act very much like 
organized hierarchically persistent bookmarks. 

Client-Service Interaction 

As described earlier, Clients find a Service using attributes described in the Service 
Vocabulary. The return value of the find { ) operation is used to further connect to 
the Service 

When Clients discover a Service, they have to specify the interface they want to use. 
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The Service provider s abstraction of the Service is a Service element as 
represented by the class ESServiceElement. 

The Service element has, among other things, the description of the Service, the 
description accessor of the Service to mutate the description, and the actual 
implementation of the Service. It also has information about the handler of the 
Service, including the queue on which messages to this Service will be sent and the 
number of threads servicing requests to this Service. 

For example, if a Service provider wants to make an existing, stand-alone 
application (such as PrinterServicelmpl), an e-speak Service, performs the 
following actions: 

1 Define or modify the interface that describes the Service interface. 

2 Create a new ESServiceElement. 

3 The Service deployer provides the description of the Service in a Vocabulary, 
along with the implementation of the Service such as the object 
PrinterServicelmpl to the Service element. The element also contains the 
description accessor of the Service that can be used by the deployer to query or 
modify the description of the Service. 

4 After performing these actions, the deployer can use the Service element to start 
the Service. The deployer can also control the concurrence of the Service by 
changing the number of threads that process the requests for this Service. The 
message queue and threads are controlled by a Service handler. 



Client - Service Interaction 

The following section provides a walkthrough of the interaction between and E- 
Speak Service and a Client that wants to use it. 

First a Service must exist for the Client to be able to find it 
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Service Creation 

A Service provider is primarily interested in implementing a Service interface to 
comply with the Contract and in advertising the Service in an appropriate 
Vocabulary. 

The steps to do this are as follows: 

1 Connect to the e-speak Core. 

2 Create a Service element 

This service element will have a description of any Service Vocabularies and 
Contracts. 

Client Service Discovery 

A Client first creates a new connection to an e-speak Core. After connecting to the 
Core, the Client can look up or register Services. The Client locates a Service that 
satisfies a constraint expressed with attributes in the default Vocabulary. 

The result of the find Service is used to communicate with the Service provider's 
Service as in Figure 3. 
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Figure 3 Client and provider Core relationship 

Client Service Usage 

Clients interact with the Service with the set of interfaces which are available in the 
Client address space. 

NOTE: When a Client invokes an operation, a well-defined e-speak custom 
serialization is used to ship the invocation to the target Service through the 
mediating e-speak infrastructure. 
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Figure 4 shows that the e-speak Core is located between the Client and the Service 
provider. In general, many Cores may lie between the Client's Core and the Core 
where the Service provider is registered. 




Figure 4 The e-speak Core 



Resource Descriptions 

E-speak makes a distinction between the data representing the state of a Resource 
and the data describing the management of the Resource. The Core mediates access 
to any registered Resource. 

NOTE: E-speak is concerned only with the Resource state of Core- 
managed Resources, not with the Resource state ofnon-Core-managed 
Resources. 
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A Resource is described to E-speak by its metadata. The metadata is composed of 
a Resource Specification and a Resource Description. The Resource Description 
consists of information that provides the means of discovery for Clients. The 
Resource Specification includes: 

• An Inbox that can be connected to the Resource Handler responsible for manag- 
ing the Resource 

• A specification of the security restrictions 

• A variety of control fields 

A Client registers a Resource by sending a message to a Resource Factory contain- 
ing a Resource Description and a Resource Specification. 

Together, Resource Descriptions and Resource Specifications include all informa- 
tion the Core needs to enforce the policies specified by the Client registering the 
Resource. If the registration succeeds, the Core returns a name bound to this 
Resource to the Inbox specified by the Callback Resource in the Outbox envelope. 



E-Speak Programming Interfaces 

There are two interface options available with E-speak: 

• Java 

• XML 

JESI based on Java, allows programmers to interact with the e-speak core or 
services through APIs (Application Programming Interfaces) 

Web Access , based on XML, enables users to interact with the E-speak core or 
services through standard web browsers, by returning HTML or XML documents in 
HTML or XML 
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JESI 

Jesi provides the interface for e-speak to environments that use programmatic 
environments such as Java. 

• In J-ESI, the connection between Clients and the E-speak infrastructure is 
represented by an ESConnection. 

• When a connection is established between a Client and the E-speak Core, 
the capabilities granted to operations performed on this connection 
depend on the credentials that are presented. 

• ESConnection supports APIs that return the Base Vocabulary and 
Contract Services. 

After a connection is established, the Client receives a 'stub' that is then used to 
communicate with the Server. 

All communications still goes through the E-speak infrastructure to insure security, 
accounting and mitigation. 

Some of the more important classes are: 

• ESContact 

• EsVocabulary 

Some of the more important methods deal with finders: 

• Vocabulary finders 

• Contract finders 

• Service finders 

• Folder finders 

Web Access 

Web access provides the interface for E-speak to standard environments in the 
Internet and XML-based e-Services solutions. Of particular interest are: 

• Provide access to e-speak services through standard web browsers, 
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• Enable e-speak services acting as services in the web (web services) , 

• Allowing invocation of standard, non-E-speak enabled web services from E- 
speak clients, 

• Provide access from and to XML-based E-speak services, 

• Allow e-speak services to interact based on the XML document exchange model 
using various transports (HTTP, TCP, VPN connections). 

The architecture of Web Access is defined in the Web Access Architecture Docu- 
ment. Web Access internally uses "E-speak XML" 1 to represent "content". 

The term "content" refers here to all kinds of information related to E-speak, 
processed by Web Access and the E-speak core. It captures functions of the E-speak 
core. 

Examples are search queries in order to find E-speak services, vocabulary descrip- 
tions, E-speak management information, service invocations and results passed 
back to requesting services and so forth. 

"Content representation" (encoding) is different at different stages in the 
system, and content needs to be transformed to interface with external systems. 

The connection points to external systems are referred to as "adapters" (inbound) 
and "agents" (outbound). 

For instance, when a user requests a service discovery through a web browser, this 
query arrives in Web Access as a HTTP FORM POST request. This representation of 
the query content needs to be transformed into internal E-speak XML for further 
processing. 

Reversely, the result represented in E-speak XML needs to be transformed into 
HTML as expected by the browser an sent back in the HTTP reply message. Prima- 
rily for the browser interface, content needs to be presented visually. "Content 
presentation" is a special kind of a transformation and is based on XSL style 
sheet transformations. 



] "E-speak XML" refers to XML in accordance with the E-speak DTD/Schema definition 



18 



Developer Release X.03.03.00, September 2000 



Introduction 



Comparing the Interfaces 



Comparing the Interfaces 

Often, the first question to arise is whether to use the Web Access (XML) base inter- 
face or Jesi (Java) based interface. Both provide similar functionality but with 
totally different paradigms. 

The Java Model is oriented toward traditional API interfaces. 
Services are described by having an API or a set of APIs. 

The client can make calls to discover services, retrieve a stub object and then 
invoke the services. These are typically synchronous methods with calls to methods 
producing results which the client will wait on. 

The XML Model, on the other hand is a document based interface that is fundamen- 
tally asynchronous. 

Services are described not by a set of APIs, but by a Schema which describes a set 
of XML documents which those services can understand. 

To find a service, a document defining the query for Services is sent to Web Access 
which will then return a document describing the Services which fit the query crite- 
ria. 

Considerations 

Computational Services 

Computational Services fit well with the API style (Java) Model. For instance, the 
Virtual File System is based on the Java model and exposes a core set of functional 
methods (Read, Write, Open, Close) which can be invoked by a client. 

Business Services 

Informational, business or broker type services fit well with the document mode. 

The API Model typically assumes that the programmer has knowledge of the exact 
interface at programming time, usually through importing the IDL definitions at 
compile time to generate the stubs needed. This means that the interface must 
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remain immutable though the life of that version of the client. If the interface 
changes or is extended, the clients must be recompiled to handle or take advantage 
of the changes. 

Changes or extensions in the document model can be discovered by the Client when 
it downloads the Schema. On the one hand the document model requires some addi- 
tional effort in parsing the Schema and handling different formats for documents, 
but on the other hand this allows greater flexibility for the Client software since it 
is possible to handle a wider range of changes with recompiling. 
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About This Document 

This document describes the E-speak Service Interface for Java programmers 
(J-ESI) , pronounced J-Easy, that is used by Clients to program on the e-speak 
infrastructure. The document explains the programming model for Clients of the 
e-speak infrastructure. This document contains the following chapters: 

• Chapter 2 provides an overview of the J-ESI, the programming model, and the 
different Services provided in e-speak. 

• Chapter 3 explains how to connect with e-speak, and how the Client and the 
Service provider create and use Services. 

• Chapter 4 explains folders, communities, categories, security, views, and events. 

• explains thread-safe programming concepts. 

• describes the messaging Application Programming Interfaces (APIs). 

• describes the command line invocation of the IDL compiler. 

• describes the interceptor mechanism in J-ESI. 

• describes the account manager in J-ESI. 

• describes the security bootstrap mechanism. 

• describes how services can be deployed and accessed across firewalls. 

• describes how to create managed e-speak services and monitor them. 

• describes the classes of checked exceptions that can be thrown by the J-ESI. 
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Introduction 

Traditionally, distributed applications have been viewed as applications that are 
run over multiple computers in a local domain. As a result, distributed 
environments have been geared toward tightly coupled applications. However, 
these environments do not meet the requirements of application deployment and 
interaction in the Internet domain. 

Applications in the Internet domain are better characterized as Services. A Service 
is a piece of software that is not tightly coupled with Client applications. Services 
are dynamically discoverable and composable entities. E-speak allows building 
such loosely coupled, distributed services by supporting the notion of a Service 
interface, a Service description that enables Services to be discovered, and by 
mediating access x.o Services. 

The e-speak infrastructure provides clear segregation of the roles played by 
different entities in enabling a robust Service ecosystem. The entities involved in 
defining Service ecosystems are categorized as follows: 

• Service standards bodies: Standardization bodies define and publish 

standardized interfaces for different Service categories that are used by Service 
developers to write Services conforming to the standardized interface. 

For example, a standards body may define a generic printer Service interface to 
contain the following invocation points: print 0, and status 0. Any Service 
provider interested in providing a printer Service writes their Service to support 
this interface. 

In addition, the standardization body is responsible for identifying the Vocabu- 
lary used to describe a Service. The Vocabulary describes the attributes that are 
used to uniquely describe a Service. For example, a printer Vocabulary includes 
attributes such as Manufacturer, Modelname, DPI and so on (perhaps using 
XML) that is used by service deployers to advertise this Service, and queried by 
Clients to discover it. 
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• Service developers: These are the developers of the actual Service 
implementation. Service developers design their Service to comply with the 
programmatic Service interfaces published by the standards bodies. Service 
developers are also able to wrap existing legacy applications so that they can be 
made available as services in the e-speak infrastructure. 

• Service deployers: Service deployers are responsible for deploying the Services 
created by the Service developers. They are responsible for advertising the 
Services in the appropriate Vocabulary and also for handling requests to the 
Service. 

• Service administrators: These administrators are responsible for monitoring, 
administering, and controlling the Service deployment. 

• Service Directories: These directories are places where service providers and 
clients can advertise and find other services that are of interest to them. 

This segregation of roles allows the Service developers to concentrate on the 
business logic of the Service that they are developing, the Service deployers to 
concentrate on advertising and handling requests to the Service, and the 
administrators to administer the Service. Furthermore, the existence of service 
directories greatly simplifies the process of building new composite services by 
providing a place where services can find other services. An example of such a 
service directory is accessible from the e-speak.hp.com site that each e-speak 
installation points to by default. 

J-ESI acts as the Java system call interface to the e-speak Core for all the above 
entities. The Core is the active entity of e-speak that acts as the mediation layer and 
routes messages to Services. 

Figure 5 shows a typical interaction between Clients and Service providers in an 
e-speak community. An e-speak community consists of a number of Cores 
connected to each other. Clients and Service providers join the community through 
these Cores. 

Clients search for Services registered in the community, and when they are 
successful, they gain access to the Service using a Service proxy (stub) of the 
discovered Service. 

The Clients need to know only the interface of the Service in order to invoke object- 
oriented functions (methods) on it. 
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Figure 5 Typical interaction between Clients and Service providers 

Unlike other distributed computing infrastructures, where the infrastructure is 
used only to locate the remote stub, in e-speak all subsequent accesses are 
mediated by the infrastructure. This mediation allows the infrastructure to enable 
very flexible security mechanisms that can be used to implement a wide variety of 
security policies. It also permits better management of the Services in the 
community for accounting, auditing, and billing purposes. The e-speak architectural 
specification has a description of the security features in e-speak. However, this 
release of J-ESI exposes only few security-related APIs. 
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Programming Model 

The primary goal of e-speakk is to simplify the development, deployment, and 
management of communities of Services on the Internet. To accomplish this, e- 
speak provides three basic abstractions: 

• Services 

• Service Contracts 

• Service Vocabularies 

In addition to these abstractions, e-speak provides system Services that enable 
Clients to write e-speak Services using J-ESI. 

E-speak Services 

Essentially, Services are programs written in a programming language such as Java, 
C, Perl, and C++. Although J-ESI makes use of some Java features, the e-speak 
infrastructure itself is not limited to any particular language. For example, a Service 
registered using J-ESI can be accessed from a Perl/Python script by using the 
appropriate e-speak library. Figure 6 illustrates the relationship between Services, 
their Contracts, and their Vocabularies. 
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Figure 6 Relationships among Services, Contracts, and Vocabularies 

Any e-speak Service conforms to its Contract because by design, it implements the 
interfaces that are outlined in its Contract. In addition, the Service is advertised in 
an appropriate Vocabulary. 

Service Vocabularies essentially provide the scheme for constructing the 
description of the Service. All three abstractions, Services, Contracts, and 
Vocabularies, are first-class entities in e-speak. By decoupling Services from the 
Contract and the Vocabulary, e-speak allows Service implementors (who develop 
the actual Service implementations conforming to certain Service Contracts) to be 
independent of Service deployers (who simply advertise the Service in a well- 
known Vocabulary) . 
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Clients are not dependent on the Service developer and deployer to communicate 
the Service Contracts and Vocabularies with which these Services have been 
described. 

The Service deployers register their Services with a group of e-speak Cores. On 
registering a Service, this Service is discoverable by others in the same e-speak 
group of Cores. 

Clients use the default e-speak finders that are provided with J-ESI, or write their 
own finders to find Services that meet their requirements. The access permissions 
of the Service determine the Services that will be visible to the Clients. On finding 
Services, Clients receive a remote stub to the Service. 

Service Contracts 

Each e-speak Service implements a set of interfaces defined in a Service Contract. 
These interfaces are often defined using the e-speak IDL, which is similar to the 
Java-RMI IDL. (See , "Messaging Classes", for additional information.) Service 
Contracts are first-class entities that can be discovered and used like any other 
Service. All Service Contracts support a base set of interfaces that provide 
mechanisms to create and query them. As a result, Contracts also can be advertised 
in a well-known Vocabulary— typically by a standardization body. 

Service Vocabularies 

A Vocabulary consists of a set of associated attributes and properties. The only 
properties associated with any attribute are the name of the attribute and the type 
of values to which these attributes are assigned. The structure of a Vocabulary is 
dependent on the vertical market for which it is defined. 

For example, the Vocabulary used to define a printer with attributes such as 
manufacturer, model name, DPI, speed, color, and cost is quite different from the 
Vocabulary that defines apparel merchandise that has attributes such as size, color, 
material, and cost. 
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Though some of the attribute names may be the same across Vocabularies, they 
may have different semantics. The attribute color in the Printer Vocabulary may be 
a boolean expression that indicates whether the printer supports color printing; 
however, the attribute color in the Apparel Vocabulary may indicate the actual color 
of the piece of clothing. 

Because Vocabularies are first-class entities, Clients and Services alike can find 
these Vocabularies registered in the community and subsequently make use of 
them. New Vocabularies are typically advertised using the Base Vocabulary that is 
available in the e-speak infrastructure. 

This Base Vocabulary defines a set of attributes that are generic and can be used by 
generic Services in markets that do not have well-defined Vocabularies. All Services 
registered as a Vocabulary conform to the Vocabulary Contract that defines the 
operations that can legally be performed on Vocabularies. 

E-speak System Services 

In addition to the base abstractions of Vocabulary, Contracts, and Services, J-ESI 
supports a set of base and extended services that makes the job of deploying and 
using Internet-wide Services simple. 

Basic Services 

These are the basic set of Services that are required to get connected to the e-speak 
infrastructure and to create and find new user-defined Services. These Services 
include the following: 

• Connection — A connection Service is used to connect and disconnect from the 
e-speak infrastructure. 

• Vocabulary — A Vocabulary Service allows the creation of new Vocabularies 
and queries the properties of existing Vocabularies. 

• Contract — The Contract Service is used to create and use Contracts. 

• Elements and Finders — Service elements are used to register Services with 
the Core, while Service finders are used to find Services. 
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Extended Services 

• Events— This Service defines a distributed Event Publisher-Subscriber model 
for Events, Events are distributed by a Distributor across any number of 
connected Cores. 

• Community — This Service enables discovery of Services across multiple 
e-speak cores. Communities are Client-side abstractions of collections of groups 
that form the search domain. The Community is a collection of member core 
groups identified by group names. 

• Folders — The Folder Service allows users to manage their Services (discovered 
or created) similar to how they manage local files in a standard operating 
system. Persistent folders appear on reconnecting and act very much like 
organized hierarchically persistent bookmarks. 

Client-Service Interaction 

As described earlier, Clients find a Service using attributes described in the Service 
Vocabulary. The return value of the find ( ) call is a Service stub that extends 
ESService and implements the operational interface specified in the find. 

When Clients discover a Service, they have to specify the interface they want to use. 
The stub is the Client-side abstraction of a Service that implements this interface. 
The Service provider s abstraction of the Service is a Service element as 
represented by the class ESServiceElement. 

The Service element has, among other things, the description of the Service, the 
description accessor of the Service to mutate the description, and the actual 
implementation of the Service. It also has information about the handler of the 
Service, including the queue on which messages to this Service will be sent and the 
number of threads servicing requests to this Service. 

For example, if a Service provider wants to make an existing, stand-alone 
application (such as Print erServicelmpl), an e-speak Service, performs the 
following actions: 

1 Define or modify the interface that describes the Service interface to conform to 
e-speak IDL. 
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2 Create a new ESServiceElement. 

3 The Service deployer provides the description of the Service in a Vocabulary, 
along with the implementation of the Service such as the object 
PrinterServicelmpl to the Service element. The element also contains the 
description accessor of the Service that can be used by the deployer to query or 
modify the description of the Service. 

4 After performing these actions, the deployer can use the Service element to start 
the Service. The deployer can also control the concurrence of the Service by 
changing the number of threads that process the requests for this Service. The 
message queue and threads are controlled by a Service handler. 

Clients, on the other hand, create instances of a stub to the Service when they do a 
find by using the e-speak finder service. They typically refer only to the interface 
that the stub implements and invoke methods in that interface. Clients could also 
choose to use the messaging APIs to communicate with Services. 



A Simple Example 

The following section provides a simple example of an e-speak Service written 
using J-ESI that illustrates some of the basic ideas in the e-speak infrastructure. 

Client Service Discovery 

A Client first creates a new connection to an e-speak Core. After connecting to the 
Core, the Client can look up or register Services. The Client locates a Service that 
satisfies a constraint expressed with attributes in the default Vocabulary. The result 
of the find Service is a stub (or proxy) to the Service providers Service. Clients can 
use this stub as a network object reference and directly invoke methods on the 
Service (see Figure 7). 
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Service provider 



Figure 7 Client and provider Core relationship 

Client Service Usage 

Clients interact with the Service with the set of interfaces for which stubs are 
available in the Client address space. Clients can preinstall the Service stubs that 
are generated using the e-speak IDL stub generator, or they may acquire the stub 
class from the Service provider by other means. From the Client's perspective, the 
nature of the Service provider is insignificant beyond the requirement that it 
implement the interface and that its attributes satisfy the query that the Client 
made. 

When a Client invokes an operation, a well-defined e-speak custom serialization is 
used to ship the invocation to the target Service through the mediating e-speak 
infrastructure. In so doing, all method invocations are effectively mediated. This 
remote invocation will work across languages and platforms, because the basic 
architecture does not depend on Java. The following code fragment illustrates a 
very simple find-and-use scenario. The Client finds a Service whose name is 
printer and invokes the print method on it. 
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ESConnection coreConnection = new ESConnection () ; 
String intfName = PrinterServicelntf . class . getName {) ; 
ESServiceFinder printFinder = 

new ESServiceFinder (coreConnection, intfName); 
ESQuery printQuery = new ESQuery ( "Name == 'printer'"); 
PrinterServicelntf printer = 

(PrinterServicelntf) printFinder . find (printQuery) ; 
printer .print (document) ; 

Figure 8 shows that the e-speak Core is located between the Client and the Service 
provider. In general, many Cores may lie between the Client's Core and the Core 
where the Service provider is registered. 




Service provider 



Figure 8 The e-speak Core 
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Service Creation 

A Service provider is primarily interested in implementing a Service interface to 
comply with the Contract and in advertising the Service in an appropriate 
Vocabulary. The Service provider first connects to the e-speak Core. The provider 
then creates a Service element with a description of any Service Vocabularies and 
Contracts. 

The register 0 method of ESServiceElement is used to register this Service with 
the e-speak Core. The Service element object also supports certain management 
APIs that allow the Service provider to start, stop, and query the status of the 
Services encapsulated in this Service element: 

ESConnection coreConnection = new ESConnection () ; 
ESServiceDescription printDescription = new 
ESServiceDescriptionO ; 

printDescription . addAttribute ( "Name" , "printer" ) ; 
ESServiceElement printElement = 

new ESServiceElement (coreConnection, printDescription) ; 
PrinterServicelmpl printerlmpl = new PrinterServicelmpl () ; 
printElement . set Implementation (printerlmpl) ; 
ESAccessor printAccessor = printElement . register {) ; 
printElement . advertise ( ) ; 
printElement . start ( ) ,* 

This code fragment creates a simple Service called printer that is implemented 
by a class called PrinterServicelmpl. The only attribute used in this example 
is the name of the Service that is set using the addAttribute method of 
ESServiceDescription. Clients can create more complex descriptions using 
custom Vocabularies, which are described in later chapters. 

Once the start method in the Service element has been called, the printer Service 
is available for other Clients in the community to access. The actual implementation 
of the Service is independent of the e-speak infrastructure. In fact, the 
implementation can very well be legacy code potentially written in any language. 

The advertise call in the code causes the description of the service to be advertised 
in the advertising directories that have been set up. By default, J-ESI advertises the 
description of the service to the e-services village service directory. Note that the 
advertising service has to be started separately in order for the advertise call to 
function appropriately. 
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Complete Example 

This section puts together the basic ideas of e-speak into a simple end-to-end 
example that illustrates the sequence of steps that have to be taken on the Service 
provider and Client side to provide and access Services. 

Typically, users have access to the IDL that defines the interface that the Service 
implements. In this example, the Clients and Service providers are assumed to have 
installed the stubs by virtue of having access to the IDL file as well as the IDL 
compiler. Although dynamic loading of the stubs is not directiy supported, it can be 
implemented in user applications using standard Java class loaders, and will also be 
supported in the next J-ESI release that incorporates the e-speak security features. 

The e-speak IDL is similar to the Java-RMI IDL. Therefore, the contents of the IDL 
files look similar to Java interface files. These IDL files must have a .esidl extension 
for the IDL compiler to recognize them as e-speak IDL files. The IDL specifications 
are found in , "Messaging Classes". 

Pr i nterServ i ce I ntf . es i d I 

The following is a sample esidl file that defines the interface to a printer Service that 
has two methods: status and print. 

public interface PrinterServicelntf { 
public String status () 

public void print {String text) 
} 

The IDL compiler generates the following files, all of which are used by J-ESI: 

PrinterServicelntf . java, 
PrinterServiceS tub . j ava , and 
PrinterServiceMessageRegistry . j ava 

Except for some minor changes, such as marking the generated interface as an 
e-speak interface, the Service PrinterServicelntf . j ava is a copy of 
PrinterService . esidl . 

Print erServiceStub . j ava is the stub class that the finder returns to the Client 
when it finds a Printer Service. 
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For every method defined in the interface, the stub class contains code to create a 
message, marshal parameters, and send it to the Service provider. 
Print erServiceMessageRegistry . j ava does not need to be used by the 
Client directly, but is used by J-ESI. 

Pr i nterService I mp I J ava 

When the IDL file is passed through the IDL compiler for Java, it produces an 
equivalent Java interface file. The Service implementor implements this Java 
interface. Therefore, the Service implementor's class (using 
PrinterServicelmpl as an example) looks as follows: 

public class PrinterServicelmpl implements PrinterServicelntf 

{ 

public String status 0 

throws ESInvocationException 

{ 

// Implementation to return the printer status 

} 

public void print (String text) 
throws ESInvocationException 

{ 

// Implementation to print the document sent by user 

} 

} 

The Service deployer advertises the Service and handles requests to the Service. 
The following code fragment is written by the Service deployer: 

public class PrintServer 

{ 

public static void main (String [] args) 

{ 

try 

{ 

ESConnection core Connect ion = new 
ESConnection( v, file.pr") ; 

ESServiceDescription printDescription = 

new ESServiceDescription () ; 
printDescription . addAttribute ( "Name" , "printer" ) ; 
ESServiceElement printElement = 



Developer Release X.03.03.00, September 2000 



35 



A Simple Example 



The Basics 



new ESServiceElement {core Connect ion, 
printDescription) ; 

printElement . setlmplementation (new 
PrinterServicelmpl () ) ; 

printElement . register ( ) ; 

printElement . start ( ) ; 

System. out. print In {"Started printer Service "); 

} 

catch (Exception e) 

{ 

// handle the exception 

} 

} 

} 

The Client also runs the IDL compiler to generate the interface and stub files, and 
makes use of the interface in the program. For instance, a Client discovers and uses 
the printer as follows: 

public class PrintClient 

{ 

public static void main (String [] args) 

{ 

try 

{ 

ESConnection coreConnection - new 
ESConnection("f ile.pr") ; 

String intfName = PrinterServicelntf . class . getName () ; 
ESServiceFinder printFinder = 

new ESServiceFinder (coreConnection, intfName); 
ESQuery printQuery - 

new ESQuery ( vx Name == 'printer'"); 
PrinterServicelntf printer = (PrinterServicelntf) 

printFinder . find (printQuery) ; 
String document - ge t Document () ; 
printer .print (document) ; 
System . out . print In {printer . status ( ) ) ; 

} 

catch (Exception e) 

{ 

// handle the exception 

} 

} 

} 
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This class is all that is required of a client application developer to find and use an 
example printer service. 
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This chapter explains the basic Services available within e-speak. The chapter 
contains the following sections: 

• Getting Connected to E-speak 

• E-speak Services 

• Client: Finding Services 

• Service Deployer: Creating Services 

• Service Description 

• Accessing Descriptions: ESAccessor 



The simple example in Chapter 2, The Basics" shows that pure Clients (e-speak 
Clients who use found Services rather than creating their own Services) and Service 
providers who provide Services have to connect to the e-speak infrastructure to 
access or provide Services, Because both pure Clients and Service providers are 
Clients of the e-speak infrastructure, they are often referred to collectively as e- 
speak Clients. 



In J-ESI, the connection between Clients and the e-speak infrastructure is 
represented by an ES Connect ion. Clients create a new instance of 
ESConnecti on when they want to connect to the e-speak infrastructure. Clients 



Getting 



Connected to E-speak 



ESConnection 
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insert all of the relevant information needed for connecting to the e-speak 
infrastructure in a configuration file that is passed as an argument to the 
constructor of the ESConnection. 

The default constructor for the ESConnect ion connects to an e-speak Core that is 
running on the local machine and is listening to requests on a port defined in the 
ESConstants file. Clients can also insert the name of a properties file that has the 
values of the properties that are relevant to establishing the connection. The most 
common fields in this property file are listed in the next subsection. 

When a connection is established between a Client and the e-speak Core, the 
capabilities granted to operations performed on this connection depend on the 
credentials that are presented. For example, if a user connects to a Core as a guest, 
the user receives restricted access and privileges compared to a user logged in as 
an administrator while operating from that connection. 

ESConnection supports APIs that return the Base Vocabulary and Contract 
Services. In addition, there are other APIs for getting management-related 
information that identifies users and the Core. The ESConnection also 
encapsulates the context of the actions that are performed by the Client. 

Property Files 

The property file parameter passed to the ESConnection constructor provides 
values for the properties that are required to connect to the e-speak infrastructure. 
For example, the property file has entries for the following properties: 

• username 

This property specifies the name of the user who is connecting to the e-speak 
Core. If the property file does not provide a value for this, the default value that 
is used is guest. 

• password 

This is the password of the user. The password along with the username form 
the user credential. 

• esurl 
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This is a colon-separated string that specifies the communication channel 
between the Client and the Core. For example, 

tcp ; rgelpc032 . rgv. hp . com: 12346 specifies that the Client connects to 
the Core running on host rgelpc032 . rgv . hp . com on port 12346 using tcp 
as the communication protocol 

• protocol 
hostname 
portnumber 

When the esurl is not specified, the Client can alternatively specify the 
elements of the connection information by explicitly specifying the protocol, 
host name, and port number. If the configuration file does not have the protocol, 
the default value for the protocol is tcp. Furthermore, if the property file does 
not have a value for the host name, the default value for the host name is local - 
host, and the default port number is 12346. 

• accountname 

Clients can provide names for their accounts so that they can reconnect to the 
same account when they connect the next time. 

• homefolder 

Applications can specify their home folder. This folder is the current working 
folder when the connection is made to the e-speak Core. 

• Timeouts 

Applications may be able to specify timeouts for various calls. Synchronous call 
timeouts can be specified with synchronous_call_timeout. Asynchronous 
call timeouts can be specified using asynchronous_send_timeout. Service 
providers can specify timeouts for messages they receive using 
asynchronous_receive_timeout. Clients can time out their find calls 
using f inder_t imeout . Timeouts are specified in milliseconds. Timeouts 
can also be changed dynamically. This can be done by calling the following 
methods on ESConnection. 

- setCallTimeout (int value); 
- setAsyncSendTimeout {int value); 
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- setAsyncRecvTimout (int value); 

- setFinderTimeout (int value); 

• eventcontrol 

This property specifies the default event control for the services being regis- 
tered. If the eventcontrol property is "0" then the core will generate an 
event when the service metadata is mutated. If it is w i" then the core will not 
generate events for service mutation. 

Connection Configuration 

Typically, Clients create an instance of an ESConnection as follows: 

ESConnection coreConnection = new ESConnection () ; 

This API connects to the core running on default hostname, which is the localhost, 
and default port, which is 12346. This API is deprecated and using ESConnection 
constructor with a property file is recommended. In this case, a transient guest 
account is created and as soon as the connection is closed, this instance of the guest 
account is removed. Alternatively, the client can connect to the Core using 

String propertyFileName = new String C w /users/connect ion. prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 

When the property file is used for creating a connection and the account name 
property in the property file is used, the following account creation rules are 
followed: 

• Where the account name property is not specified, a transient guest account is 
created. However, if the account name is provided and no previous account of 
this name exists, a new account with the user and password is created. 

• Where the account already exists and the user credentials are validated, the 
connection returns a connection with the last saved state associated with the 
same user credential. 

After having connected to the Core, the Client can retrieve the parameters of the 
connection by entering 

ESConf iguration config = coreConnect ion. getConf iguration () ; 
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The following methods in the ESConf iguration class allow the Client to retrieve 
the various parameters of the connection: 

public class ESConf iguration 

{ 

public ESUserCredential getUserCredential { ) ; 
public String getHostName () ; 
public int ge t Port Number () ; 
public String getProtocol () ; 
public String getURLO? 

public void setHostName (String hostName) ; 

public void set Port Number (int portNumber) ; 

public void setProtocol (String protocol); 

public String getConnectionName ( ) ; 

public void set Connect ionName (String name); 

public String getGroupName ( ) ; 

public void setURL (String url) ; 

public int getCallTimeout ( ) ; 

public int setCallTimeout ( int newVal ) ; 

// . . refer to javadoc for other methods 

} 



E-speak Services 

There are two abstractions for a Service: 

• Service providers — Service elements (ESServiceElement) that are used by 
Service providers to deploy and manage a Service. 

• Clients — Service stubs (ESService) that are used by Clients to access an e- 
speak Service. 

Service providers take the following steps to create a Service: 
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1 The Service developer provides implementation of the Service interface. These 
interfaces are encapsulated in the Contract to which the Service conforms. The 
actual implementation need not contain any e-speak-specific code. 

2 The Service deployer then describes the Service in a chosen Vocabulary by 
setting the attribute values appropriately. The ESServiceDescript ion class 
is used to set these attribute values. 

3 The Service deployer and/or administrator then creates a new 
ESServiceElement that registers and starts the Service so that other Clients 
of the e-speak infrastructure can find and use the Service. (See Figure 9.) 



PrinterServtcelntf 




Figure 9 Creating an ESServiceElement 

Clients typically take the following steps to find and use a Service: 

1 Clients find Services using a Service finder that accepts queries in the 
Vocabulary that was used to advertise the Service. Clients also specify the 
interface that they expect to use to invoke the Service. 

2 On finding a match, the Clients get a handle to a Service stub that can be used to 
invoke the methods that are implemented by the Service provider (see Figure 9) . 
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The Client or Service deployer can choose to examine or modify attribute values. 
This is accomplished using the ESAccessor class. 

All the three basic entities (Vocabularies, Contracts, and other Services) in e-speak 
can be created or found in the same manner. 

The main difference between generic Services and Contracts or Vocabularies is that 
the interface for Vocabularies and Contracts is defined by the e-speak Core. The 
Core is the handler for any Vocabulary or Contract method. 

Generic Services on the other hand, are not handled by the Core, and can have 
arbitrary interfaces that meet the requirements of the specific Service. The rest of 
this section describes the well-defined interfaces supported by Contracts and 
Vocabularies in the e-speak Core. 

ESContract 

Just as a Vocabulary determines the scheme for describing the attributes of 
Services, the Contract determines the type of Service as represented by the 
interfaces that it implements. Just as the Core is the handler for Vocabularies, the 
Core is the handler for Contracts as well. 

The following method returns the name of the Contract; the name of the interface 
that this Contract encapsulates: 

public String getlnterf aceName ( ) ; 

The following method returns the IDL string associated with the Contract; 

public byte [] getlnterf aceDef inition (} ; 

In addition, the ESContract has methods that return the conversations that the 
service supports, the terms and conditions of use, and the license policy. The 
following entry points in ESContract are the relevant entry points. 



public String get Conversation Scheme { ) ; 
public String getTermsOf Use ( ) ; 
public String getLicense ( ) ; 
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A Base Contract is available in the Core that Clients can obtain by invoking the 
getBaseContract method in the connection object. For example: 

String propertyFileName - new String ( "/users/connection .prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 

ESContract baseContract = coreConnect ion. getBaseContract () ; 

ESVocabulary 

In the e-speak infrastructure, Vocabularies are also Services that are discovered by 
Clients. When the Client discovers a Vocabulary, the Client receives a stub that 
conforms to the ESVocabulary interface. However, the Service provider for the 
Vocabulary is the e-speak Core itself. 

After a Vocabulary has been defined, Clients of the Vocabulary can only query its 
contents to determine what properties this Vocabulary defines. The Clients cannot 
change the properties of the Vocabulary. Furthermore, they can query the core for 
all the services that are registered in this vocabulary. There are two main APIs in 
ESVocabulary: 

public ESPropertyH getProperties ( ) ; 
public ESAccessor[] getServices { ) ; 

The conversation scheme, terms of use, and licensing policy are not available for 
the base contract. 

Base Vocabulary 

The Base Vocabulary comes preloaded with e-speak. This Base Vocabulary has pre- 
defined properties that can be used to describe Services. Service providers do not 
have to invent their own Vocabulary to describe their simple Services. The Base 
Vocabulary has basic attributes that can represent the name of the Service, the type 
of Service, and other similar characteristics that are universal to many Services. 

The base Vocabulary can be retrieved from an ESConnection using the 
getBaseVocabulary ( ) method. The following code fragment shows how 
Clients get the Base Vocabulary: 



46 



Developer Release X.03.03.00, September 2000 



Basic Services 



Client: Finding Services 



String propertyFileName = new String ( "/users/connection .prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 

ESVocabulary baseVocab = coreConnection .getBaseVocabulary () ; 

The following table shows some of the important properties that are defined in the 
Base Vocabulary. No other vocabulary should define and use 'Name', Type 1 and 
'ESGroup* as these attributes are reserved and are used by the J-ESI library 
internally. 



Table 3 Base Vocabulary properties 



Attribute name 


Type 


Description 


Name 


String 


Name of the Service 


Type 


String 


Type of Service 


ResourceSubType 


String 


Subtype of Service 


Description 


String 


Description of the Service 


Version 


String 


Version of the Service 


ESDate 


Date 


Date associated with the Service 


ESGroup 


String 


Group associated with the Service 


ESTime stamp 


Timestamp 


Timestamp associated with the Service 


ESCategory 


String 


Stringified list of categories that any 
service is advertised in. 



Client: Finding Services 

Clients to the e-speak Core typically find Services that match certain constraints. 
The kinds of finders are visible to the Client are: 
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• Vocabulary finders 

• Contract finders 

• Service finders 

• Folder finders 

• View finders 

You can extend these finders to suit your needs or to use the APIs supported in 
these classes directly. 

Setting Search Level in Finders 

The following search level operations are possible in the finders.These methods are 
present in the abstract class ESAbstractFinder and are visible to all the derived 
finder classes such as ESServiceFinder and ESContractFinder: 

public void setMaxToFind { int maxToFind) 
public int getMaxToFind ( ) 

Using the above set method, it is possible to set the number of maximum services 
that should be returned as a result of a find call. The get method returns the current 
setting. The default maximum value is 1000. 

public void setSecurityLevel (boolean flag) 
public boolean getSecurityLevel { ) 

Passing a true in the above set method enables stub classes to be dynamically 
downloaded from the service provider. Passing a false will allow classes to be 
loaded only from the local classpath. The getter returns the current settings for the 
security level. By default, the stub classes will be loaded only from the local 
classpath. 

public void setSearchLevel (int flag) 
public int getSearchLevel { ) 

The above methods allow the user to set the level for searching the services. Passing 
ESConstants . LOCAL_ONLY will restrict the search for services to the local core 
repository irrespective of the community settings. ESConstants . LOCAL_ADV 
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will restrict the search to local repository and local group. 
ESConstants . ADV_ONLY will result in the search being conducted in the 
community. The default is that the search will be conducted in LOCAL__ADV mode. 

ESContractFinder 

The ESContractFinder class is used by Clients to find Contracts. Contracts are 
Services that are registered with the e-speak Core just like any other Service. The 
Contract Finder finds only Services that have been registered as Contracts. The 
attribute that is used to distinguish between Contracts is the Name attribute in the 
Base Vocabulary. There are three important entry points in ESContractFinder. 
These are: 

public ESContract find(ESQuery query); 
public ESContract [] f indAll (ESQuery query); 
public ESContract [] findNextO; 
public void setMaxToFind (int number); 

The find method finds a single contract that matches the constraints and 
preferences in the query. The findAll finds all contracts that match the query subject 
to the maximum number of services set in the finder. 

For example, to find a Contract named PrintContract, use the following code 
fragment: 

String propertyFileName = new String { "/users/connection. prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 
ESContractFinder printContractFinder = 

new ESContractFinder (coreConnection) ; 
ESQuery print Contract Query = 
new ESQuery { "Name * PrintContract '") ; 
ESContract printContract = 

printContractFinder . find (printContractQuery) ; 
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The ESVocabularyFinder class is used by Clients to find Vocabularies. Finding 
a vocabulary is done more often than creating a vocabulary. Vocabularies are 
usually defined by some standard body. For example, a standard body might define 
a printer vocabulary which contains attributes like the speed of the printer, its 
location, etc. The definition of the vocabulary happens only once. It is likely that 
this vocabulary is registered in a community of interest. Any printer which wants to 
conform to this standard body finds the vocabulary and registers the printer service 
using this vocabulary. 

Because a vocabulary is also a service, it needs to be advertised as well. Usually 
vocabularies are advertised in the default vocabulary. It is also possible to advertise 
a vocabulary in another non default vocabulary. 

public ESVocabulary find(ESQuery query); 

public ESVocabulary [ ] f indAll <ES Query query); 

public ESVocabulary [] f indNext { ) ; 

public void setMaxToFind (int number); 

For example, to find a Vocabulary named printerVocab, use the following code 
fragment: 

String proper tyFileName = new String ( "/users/connection. prop" ) ; 
ESConnection coreConnection = new 
ESConnection CpropertyFileName) ; 
ESVocabularyFinder printVocabFinder = 

new ESVocabularyFinder (coreConnection) ; 
ESQuery printVocabQuery = 

new ESQuery ("Name 'printerVocab'"); 
ESVocabulary printVocab = 
printVocabFinder . find (printVocabQuery) ; 

Instead of using ESQuery, you can find a vocabulary using an XML query using 
ESXMLQuery. 
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ESServiceFinder 

The ESServiceFinder class is a generic finder class that is used to find user- 
defined Services. The interfaces here look similar to the ESContractFinder and 
ESVocabulary finder. 

public ESService find(ESQuery query); 
public ESService [] f indAll (ES Query query); 
public ESService [] findNextO; 
public void setMaxTof ind ( int number) ; 

The ESServiceFinder class has two constructors. One constructor which takes 
only ESConnection as parameter, find/f indAll in this case will return the base 
stub (ESService) from which all other stubs derive. The second constructor takes 
ESConnection and the interface name (or ESContract) as parameters, find/ 
f indAll in this scenario returns the stub for the Service provider. When the 
interface name is specified for doing a find, the client library sends an introspection 
request to the potential service providers. The service providers that respond 
correctly to the introspection request are returned as results. This means that when 
the interface name is used in the find, the services that the finder returns were 
known to be up and ready at the time of the find. No such guarantee can be made 
when the finder is used without the interface name. If the Service provider is not 
running, the call times out if the finder timeout is set. More details on how to set the 
timeouts is available in the later sections. 

The ESServiceFinder class can return multiple Services as the result of a query. 
However, Clients can control the maximum number of Services that are returned as 
the result of a find by entering the following code: 

public void setMaxToFind (int number); 
public int getMaxToFind ( ) ; 

Chapter 2 presented an example of a Client that searches for a simple printer that 
is described in the base Vocabulary. A slightly more complex example of a Printer 
that has been advertised in a non-Base Vocabulary, called a print erVocab, 
requires the following code to find the printer: 

public class PrintClient{ 
public static void main {String [] argv) { 
try { 

String propertyFileName = 

new String ("/users/connection. prop") ; 



Developer Release X.03.03.00, September 2000 



51 



Client: Finding Services 



Basic Services 



ESConnection coreConnection = 

new ESConnection (propertyFileName) ; 
// find vocabulary 

ESVocabularyFinder printVocabFinder = 

new ESVocabularyFinder (coreConnection) ; 

ESQuery printVocabQuery = 

new ESQuery ( "Name ™ * PrintVocab' ") ; 

ESVocabulary printVocab = 

printVocabFinder . find (printVocabQuery) ; 

// find contract 

ESContractFinder printContractFinder = 

new ESContractFinder (coreConnection) ; 
ESQuery print ContractQuery = 

new ESQuery ("Name == * Print Con tract '") ; 
ESContract printContract = 

printContractFinder . find (printContractQuery) ; 
// find service described in vocab that conforms to 
contract 

ESServiceFinder printFinder = 

new ESServiceFinder (coreConnection, printContract); 
ESQuery printQuery = new ESQuery (printVocab) ; 
print Query . addConstraint ( "DPI == 14 00"); 
PrinterServicelntf printer = (PrinterServicelntf ) 

printFinder . find (printQuery) ; 
String document = getDocument ( ) ; 
printer .print (document) ; 
} catch (Exception e) 
{ 

// handle the exception. 

} 

} 

} 

The finder class also supports a cursor like mechanism for clients to traverse the 
result set obtained as a result of performing a f indAll ( ) operation. The cursor 
mechanism is quite common in relational database APIs such as JDBC. In JDBC, the 
result of executing a query is a result set, and the client program can loop based on 
a condition that depends on whether there are additional rows in the result set. In 
J-ESI, on the other hand, the finder itself acts as the result set. On invoking a 
f indAl 1 ( ) operation on the finder, the finder acts as a cursor. The client program 
can determine whether there are other services found by the finder by invoking the 
hasMoreResul ts { ) method on the finder. In addition, the next set of results can 
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be obtained from the finder by invoking the f indNext ( ) method. In the example 
below, the query essentially finds all the services that are registered in the printer 
vocabulary. It then proceeds to retrieve the services that are found two at a time. 



33public static void main( String [] args ) { 
try { 

String propertyFileName = new String ( "/users/ 
c onnect ion. prop " } ; 

ESConnection conn = new ESConnect ion (propertyFileName) ; 
ESVocabularyFinder vf = new ES Vocabulary Finder (conn) ; 
ESVocabulary v = null ; 
try { 

v = vf.find( new ESQuery { "Name == ' print erVocab '")) ; 
} catch ( LookupFailedException ffe ) { 
f fe .printStackTrace {) ; 
return ; 

} 

ESServiceFinder finder - new ESServiceFinder (conn) ; 
ESQuery query = new ESQuery (v, " (Name == 'printer') or (Name != 
'printer' ) ") ; 
ESService[] serviceList = null; 
int total_f indall_services = 0; 
finder . setMaxToFind (2) ; 
serviceList = f inder. findAll (query) ; 
total_f indall_services += serviceList . length; 
while ( finder -hasMoreResults () ) { 
serviceList = f inder .f indNext {) ; 

// . . do stuff with services found in service list. 
System. out .print In ("number of services got: " + 
serviceList .length) ; 



} catch ( Exception ex ) { 

exl . printStackTrace ( ) ; 

} 

return; 

} 
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In general Clients use the ESQuery class to construct queries that are either not 
simple name lookups in the Base Vocabulary or are constraints that are expressed 
in a Vocabulary that is different from the default Vocabulary, The ESQuery class has 
methods that allow the client to add constraints that make up the query. These 
constraints are string constraints whose syntax is similar to the syntax of constraint 
specification in OMGs OTS specification. Essentially, every constraint is parsed as 
if it were a disjunction of conjunctions, i.e., the constraint expression is expected 
to be in disjunctive normal form. 

More formally, the context-free grammar that defines the syntax of the constraint 
strings is as follows: 

<Expr> : : = <OrExpr> 
<OrExpr> ::= <AndExpr > 

| <OrExpr> x or' <AndExpr> 
<AndExpr> : : - <NotExpr > 

| <AndExpr> 'and' <NotExpr> 
<NotExpr> <EqualityExpr> 
| 'not' < Equal ityExpr> 
<EqualityExpr> Relational Expr> 

| <RelationalExpr> { <OpEqual> | M = ' ) <RelationalExpr> 
<RelationalExpr> : := <InExpr> 

| <InExpr> <OpRelational> <InExpr> 
<InExpr> ::= <AdditiveExpr> 

| <AdditiveExpr> 'in' <AdditiveExpr> 

| <AdditiveExpr> 'in' <ListExpr> 
<AdditiveExpr> : := <MultiplicativeExpr> 

| <AdditiveExpr> <OpAdditive> <Mult iplicativeExpr> 
<MultiplicativeExpr> ::= <UnaryExpr> 

| <MultiplicativeExpr> <OpMultiplicative> 

<UnaryExpr> 

<UnaryExpr> : := <UnionExpr> 

| * - x <UnaryExpr > 

| 'exist' <PathExpr> 
<UnionExpr> : := <PathExpr> 

| <UnionExpr> ' | ' <PathExpr> 
<ListExpr> ::= *p <Arguments> ']' 
<PathExpr> : : = V 

j V <RelativeLocationPath> 
| % //' <RelativeLocationPath> 
| <RelativeLocationPath> 
| <FilterExpr> 
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| <FilterExpr> V <RelativeLocationPath> 
| <FilterExpr> *//' <RelativeIiOcationPath> 
<FilterExpr> ::= <PrimaryExpr> 

| <FilterExpr> <Predicate> 

<RelativeLocationPath> = <Step> 

| <RelativeLocationPath> V <Step> 
| <RelativeLocationPath> v //' <Step> 

<PrimaryExpr> : := <NCName> 

| 1 ( * <Expr> 1 ) ' 

| <Literal> 

| <FunctionCall> 

<FunctionCall> : := <FunctionName> M* <Arguments> *)' 
<Arguments> : :~ <Expr> 

| <Arguments> v , ' <Expr> 

<Predicate> : := *p <Expr> 
<Step> ::= <StepPredicate> 

I 
I 

<StepPredicate> ::= <AxisSpecif ier> <NodeTest> 

| <StepPredicate> <Predicate> 

<AxisSpecif ier> : : = <AxisName> 1 : : ' 

| »@' 
e 



<NodeTest> 



String_Lit 1 ) 
<NodeType> : : = 
<AxisName> : : = 



'namespace 1 

<Qname> : : = 
<Literal> : 



1 comment' 
1 ancestor ' 



<NCName> 

<Number Lit> 



<NCKame > 1 : ' 1 * ' 
<QName> 

NodeType s ( y x ) ' 

"processing- instruction' 1 ( v 



'text' | x node' 

| 'ancestor-or-self 1 | 'attribute* 

| 'child' | 'descendant' | ' descendant -or- self ' 

| 'following' | x foil owing- sibling ' | 

| 'parent' | 'preceding* | 'preceding-sibling' 
| 'self 

I <NCName> 1 : ' <NCName> 



<OpEqual: 



| <String_Lit> 

I <Boolean_Lit> 

I <Date_Lit> 

I <Time_Lit> 

| <TimeStamp_Lit> 
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<OpRelational> : := | | | | » & i t ;' | »<-' | *>' \ 

s &gt ; = ' 

<OpAddtive> : := x +' | 

<OpMultiplicative> ; := <MultiplyOperator> | *div' | 'mod' 
<NCName> : := { <Letter> | )? <NCNameChar>* 

<NCNameChar> <Letter> | <Digit> | | * - ' | 

| <CombiningChar> ) <Extender> 
<Number_Lit> <Digit>* * <Digit>+ { ( 'E' j v e' ) ( * + ' I 

* ) <Digit>+ } 

<String_Lit> ::= [ <AnyChar>^"" ]* w " 

| 1 " C <AnyChar>*' ' ' ] * 

<Boolean_Lit> ::= true | false 

<Date_Lit> : : = ( *d' | *D' ) WhiteSpace* (CC | YY? *-* MM? x - 

1 DD v } ' 

<Txme_Lit> :: = »{' (*f | 'T') WhiteSpace* HH * : ' MM ^ : % SS 
SSS S* )? ( V Z' | * - 1 MM * : ' SS ) ? 1 } ' 

<TimeStamp_Lit> :: = { *f | *T' ) { »s' | 'S' ) WhiteSpace* CCYY 

MM DD "I" <Time_Lit> 

Example query strings include: 

"TestStrl + 'String2' == ' StringlString2 • and Testlnt - 5 < 10 and 

TestDouble < 30" 

"TestDate > {d 1980-08-21} and TestTime stamp <= {ts 1992-05- 

12X05:33:44.111111000}", 

"Testlnt * 2 >= 22 and not (TestDouble >= 55.550)", 

"Testlnt > 10 or TestDouble == 10 or TestFloat > 10.0", 

"TestBool != TRUE or Testlnt -10 <= 10 and 2345.99 >= TestBigDecimall\ 

The specialization of ESQuery called ESXMLQuery can be initialized from a file 
that contains a query for a Service expressed in XML: 

public ESXMLQuery (ESConnection coreConnection, 
ESXMLFile xmlQueryFile) ; 



Finding Services Using XQL 



XQL can be used to find a printer described in printervocab. See , M IDL 
Compiler", for more details about XML DTDs used in e-speak. 

The following XML page describes an XQL-based search that is passed to the 
ESQuery constructor: 

<?xml version="1.0"?> 
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<ESpeak vers ion="E- speak 1.0" operation="FindService" > 
< resource > 

<!-- The search query- -> 
<query> 

<queryBlock> 
<WHERE> 

<!-- Begin: Specify printer Vocabulary --> 
<query> 

<queryBlock> 
< WHERE > 

<condition> 

<IN> 

<pattern> 

<Name >pr int ervocab< /Name > 
</pattern> 
</IN> 
</condition> 
</WHERE> 
</queryBlock> 
</guery> 

<]-- End: Specify printer Vocabulary --> 
<!-- Begin: search conditions --> 
<condition> 

<predicate lexpr="DPI" rexpr="1400" RelOp="eq"/> 
</condition> 
<!-- End: search conditions --> 
</WHERE> 
</gueryBlock> 
< /query > 
</resource> 
</ESpeak> 

The Service to be discovered is specified by means of a query. An embedded query 
specifies the attribute Vocabulary in which attributes for the query conditions are 
specified. In this case, assume that this XML fragment is in a file called 
printFinder . xml. 

The query searches in the Vocabulary called printervocab for a printer whose 
DPI attribute has a value of 14 0 0. 

<?xml version^ 1 1 . 0 r ?> 

<esquery xmlns= "http : //www. e- speak. net /Schema/E- 
speak . query . xsd" > 

<result>$service!nfo< /result > 
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< where > 

<vocabulary name= M printervocab" src= ,, printervocab ,, /> 
<condition> 

printerVocab:DPI = 1400 
</condition> 
</ where > 
<preference> 
</pref erence> 
<arbitration> 

<operator>first< /operator > 
<cardinality>all</cardinality> 
</arbitration> 
</esquery> 

There is also a constructor for ESXMLQuery that takes two ESXMLFiles as 
arguments: 

public ESXMLQuery ( ESConnection connection, ESXMLFile xmlHeader, 
ESXMLFile xmlRequest ) ; 

In the example above, in the line where printQuery is constructed, this constructor 
is used instead of the constructor that takes in a single xml file. In addition, the 
contents of the xmlHeader file look as follows: 

<?xml version= f 1.0' ?> 

<header xmlns="http: //www. e- speak .net /Schema/E- 
speak . header . xsd" > 
< communication 

<to>es : / /localhost : 12346/WebAccess/FindService</to> 
< / communi c a t i on > 
</header> 

Queries in Multiple Vocabularies 

The query can be constructed in multiple vocabularies. This feature of being able to 
specify queries in multiple vocabularies is similar to the notion of formulating 
queries in SQL that query multiple tables. Follow the steps detailed below to specify 
a query in multiple vocabulary. 

1 Specify a key for each vocabulary using the following method available in 
ESQuery: 

public void addVocabulary Key (String key, ESVocabulary vocab) ; 
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e.g., query. addVocabularyKey { "print ervocab" , vocabl) ; 
query . addVocabularyKey ( "def aultvocab" , vocab2) ; 

2 Specify the constraint in "keyrattr" form instead of simple "attr" form. 

String myConstraint « « (printerVocab : Manufacturer == 'Acme' && 
def aultvocab: Name == ' myPrinter 1 ) " ; 

Constraint specifies conditions that services of interest must satisfy. The lookup 
service evaluates constraint against service descriptions in the repository and 
returns a set of matching services. Sorter is applied to the resulting set of services 
to order the services. Arbitration policy is used to limit the size of the resulting set 
if the constraint evaluation results in multiple services. 



match w/ 
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Figure 10 Order of Application for Service Sorting 

The above figure illustrates the order in which constraint, sorter, and arbitration are 
applied to found services. 

The query can be enhanced with a sorter. The specification of a sorter is similar to 
a notion of "order by" construct in SQL. Essentially, the user gets the finder to return 
the services using the order specified in the sorter parameter. This specification is 
done by the addSorter entry point in ESQuery. 

public void addSorter (int type, String expression); 
public void addSorter (String condition, String weight); 

The first method takes in two arguments. The first argument should be either 
ESConstants . SORTER_OPERATOR_MIN or 
ESConstants . SORTER OPERATOR MAX. 
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They correspond to whether the results should be sorted in ascending or 
descending order respectively. The second argument is an expression involving the 
attributes. For example, if there are three attributes in a vocabulary — length, 
height, and width — then we should be able to specify a sorter as follows: 

query . addSorter {ESConstants . SORTER_OPERATOR__MIN, 
"length*height*width") ; 

The second method also takes in two arguments. The first argument is the condition 
expression and the second argument is the weight expression. The condition is 
evaluated for each service and if the condition returns true, then the weight is 
added. There can be multiple such expressions. All the weights are added and the 
results are returned in the order of decreasing weights. In case of a tie, the max or 
minimum (if specified) is applied to break the tie. 

query. addSorter ("length < 5", "10"); 
query. addSorter ("weight < 10: f "2"); 

It is possible to specify an arbitration policy in the query. This is done with the 
following method. 

public void setArbitrationPolicy (int policy); 

The values allowed are ESConstants . ARBITRATION_POLICY_ALL and 
ESConstants . ARBITRATION_POLICY_ANY. The first value results in all the 
services being returned and the second value results in any one the services being 
returned. 

Using Introspection 

When finding Services, sometimes the Client wants to know all the Service 
interfaces supported by the Service the Client has found. The most likely use of this 
scenario is in browsers, where the user is presented with a set of choices. This is 
possible in an e-speak environment using the introspection facility. The Client can 
get a handle to a service without knowing the interface it supports, and after getting 
the handle can query the Service to find all the Service interfaces the Service 
supports. The Client can also get a Service stub corresponding to a particular 
interface and can invoke operations on it. An example follows: 
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ESServiceFinder printFinder - new 
ESServiceFinder (coreConnection) ; 

ESService printer = printFinder . find (printQuery) ; 
ESHashMap allSupportedlnterf aceMap = 

( (ESIntrospectionlntf) printer) .getlnterf aces ( ) ; 

allSupportedlnterf aceMap contains a map of interface names and the actual 
class of the interface. The Client can find whether the Service supports a particular 
interface of interest and then get the stub corresponding to it using 

PrinterManagementlntf mg = ( (ESStubFactorylntf } 
printer) .getServiceStub ( "PrinterManagementlntf " ) ; 

Another use of introspection is in the development of lightweight Clients. The 
Clients do not need to have any of the class files like the interface, stub files, and so 
forth. All these can be obtained using introspection and stub factory interfaces, and 
methods can be invoked using Java reflection. Thus introspection and stub factory 
interfaces allow building truly dynamic, lightweight, and scalable solutions. 



Service Deployer: Creating Services 

The previous section explained how a Client gains access to Services created by 
others. This section explains how Service providers create Services. As described 
earlier, Service providers perform the following sequence of operations in creating 
and managing the Service: 

1 Create a description of the Service that uses the chosen Vocabulary. 

2 Create a Service element that encapsulates the description and associates an 
implementation and a handler for the Service. 

3 Register and start the Service. 

4 If necessary, mutate the metadata of the Service, 
As with the finders, there are five kinds of elements: 
• ESContractElement 
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• ESVocabularyElement 

• ESServiceElement 

• ESFolderElement 

• ESViewElement 

A similar set of classes encapsulates the descriptions of Services: 

• ESContractDescription 

• ESVocabularyDescription 

• ESServiceDescription 

• ESViewDescription 

• ESFolderDescription 



Service Description 

Service descriptions are sets of attribute-value pairs expressed in a certain 
Vocabulary describing the Service. The Vocabulary determines the names and types 
of the attributes used in the description of the Service. For instance, a printer 
Service can be described in a Printer Vocabulary. The Printer Vocabulary in turn 
can contain attributes such as DPI that takes on an integer value, Manufacturer , 
that takes on a string value , and Mode Iname that takes on a string value. The printer 
itself is identified by the fact that it is manufactured by a particular manufacturer, 
has a particular model name, and prints at a particular DPI value. 

Vocabularies, in turn, have to be described, and e-speak breaks the recursion using 
a Base Vocabulary that has predefined attribute properties described earlier. 

All Service Descriptions are associated with two kinds of attributes: 

• Searchable attributes — Those used in queries by Clients.These are also the 
attributes listed in each Vocabulary. 
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• Service-specific data (Data)— This data, which is stored along with the 
description of the Service, cannot be searched for, but can be accessed. This 
data can be as simple as String entries, or as complex as arbitrary byte code. For 
example, one Datum in the printer description may be the administrator s 
contact information (such as a phone number). 

In the current API, there are two ways of specifying the descriptions: 

• Using XML (This is the recommended method for specifying descriptions.) 

• Using the e-speak description of objects provided in the Client library 

Searchable Attributes 

The attributes that can be part of any Vocabulary can be in one of the 14 e- 
speakbase types: 

• String • boolean 

• byte • char 

• short • int 

• long • float 

• double • BigDecimal 

• Date • Time 

• Timestamp • byte [] 

The ESBaseDescription class supports the addition of attributes by the 
addAttribute method. These calls take two parameters, the first is the name of 
the attribute, and the second parameter is the value of the parameter. 

ESContractDescription 

Contracts are also Services in the e-speak infrastructure. Contracts are typically 
described using the Base Vocabulary. Contracts encapsulate the Service IDL to 
which the Service is guaranteed to conform. 

The setlnterf aceDef inition methods set the IDL associated with the 
Contract: 
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public void setlnterf aceName (String intfName) ; 
public void setlnterf aceDef inition (String idlString) ; 
public void setlnterf aceDef inition (byte [] intf Class) ; 
public void setConversationScheme (String scheme); 
public void setTermsOfUse (String terms); 
public void setLicense (String license); 



The following code segment explains how to create a contract using the contract 
description. 

String propertyFileName = new String ( Vusers/conection. prop" ) ; 
ESConnection coreConnection = new 
ESConnect ion (propertyFileName) ; 

ESContractDescription printContractDescription = 

new ESContractDescription () ; 
printContractDescription. addAttribute ( "Name" , "PrintContract" ) ; 
printContractDescription - setlnterf aceName 

( "printer . PrinterServicelntf " ) ; 
String idl = getlDLFromFile ( "PrinterService .esidl" ) ; 
printContractDescription . setlnterf aceDef inition (idl) ; 

ESContractElement printContractElement = 

new ESContractElement (coreConnection, 
printContractDescription) ; 

ESContract printContract = printContractElement .register () ; 



ESVocabularyDescription 

This class is used to describe a new Service Vocabulary that is used in descriptions 
of other Services. As noted earlier, the printer Service is described in the Printer 
Vocabulary. 

There are two parts to describing a Vocabulary. First, because Vocabularies are 
Services that can be discovered, the attributes of the Vocabulary need to defined so 
that Clients and Service providers can discover the Vocabulary. Second, the 
properties of the Vocabulary need to be defined so that any Service that is 
registered in this Vocabulary has the same properties. These properties can also be 
used to build queries to find Services. 
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Vocabularies are somewhat analogous to a table schema in relational databases. 
The properties that make up the Vocabulary are the columns of the table, and each 
Service that is registered in the Vocabulary becomes a row in the table. In keeping 
with the database analogy, it is assumed that the names of the properties in a 
Vocabulary are case insensitive. 

Clients who are creating Vocabularies can set the name of the new Vocabulary they 
want to create using the addAttributeO method in the ESBaseDescription class. 

Just as Service descriptions contain 14 basic attributes in e-speak, the Vocabulary 
descriptions can contain properties in those 14 types: 

• String 

• boolean 

• byte 

• char 

• short 

• int 

• long 

• float 

• double 

• BigDecimal 

• Date 

• Time 

• Timestamp 

• byte [] 

Typically, Clients make a series of calls that add various named properties. For 
example, to create a description of a printer Vocabulary that has three properties 
corresponding to the manufacturer, model name, and DPI and that indicates that a 
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particular property is mandatory (meaning that any Service registered in this 
Vocabulary has to provide a value for this property), use the following code 
fragment: 

String propertyFileName = new String < Vusers/conection. prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 

ESVocabularyDescription printVocabDescription = 

new ESVocabularyDescription () ; 
printVocabDescription .addAt tribute { "Name" , "PrintVocab" } ,* 
printVocabDescription . addStringProperty ( "Manufacturer" ) ; 
printVocabDescription . addStringProperty ( "Modelname" ) ; 
printVocabDescription . addlntegerProperty ( "DPI" ) ; 

ESVocabularyElement printVocabElement = 

new ESVocabularyElement (coreConnection, 
printVocabDescription) ; 

ESVocabulary printVocab = printVocabElement . register {) ; 

Specifying Additional Information and Essential Properties of a Vocabulary 
Property 

The example on the previous page shows registering a simple vocabulary. It can be 
seen that in the example, for each property in the vocabulary, its name and type are 
stated. For instance, addStringProperty { "Manufacturer »* ) results in a 
vocabulary property whose name is "Manufacturer" and type is a String. However, 
it is possible to give more information about a vocabulary property using the 
es Property class, such as in the following example: 

public ESProperty (String attrName, String attrType, ESValue 
defValue, boolean isMandatory, boolean isMultiValued, int 
rangeKind, int minRange, int maxRange, int index) 

where the above terms have the following definitions: 

• attrName — the name of the property 

• attrType —the type of the property. The type could be any one of the fourteen 
data types supported. 

• defValue —the default value assigned to the property. 
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• isMandatory —specifies whether the property is an essential property or an 
optional property. If the property is an essential property, any services 
registered in the vocabulary has to specify a value for this property during 
registration. A » true ' for this parameter means that the attribute is mandatory, 
anda 'false 1 means that it is not. This works only for an in-memory case. When 
the system is operated in JDBC mode, all the attributes are considered non- 
essential. 

• i sMul t i va lued —specifies whether the property can have multiple values or 
not. A • true ' for this parameter states that the property is multivalued and a 
'false ' informs the core that the property is single-valued. 

• range Kind , minRange and maxRange — specify what values that the property 
can take. The rangeKind can be one of the following: ESConstants . no_range , 
ESConstants . LEFT_RANGE, ESCons t ants . RIGHT_RANGE, and 
Esconstants . full_range . The possible values that the attribute can take is 
determined by minRange, maxRange, and rangeKind parameters. The 
rangeKind parameter determines whether the range is to the right of maxRange , 
to the left of minRange , or occupies the full range. 

• index —specifies whether the property should be used for indexing the 
database and if so what type of indexing. This can take the following values. 
ESConstants . NO_INDEX, ESConstants . HASH_INDEX and 
Esconstants . tree_ index . Hash or Tree indexing should be chosen based on 
the kind of queries that is likely to be made. If the queries are likely to be equality 
queries (" PrinterName -Acme ■ ") , it is suggested that hash indexing is used. 
If the queries are likely to be range constraints ("Speed < 10 ") , then tree 
indexing gives better performance. Hash or tree indexing makes a difference 
only in in-memory mode. In JDBC mode, they are ignored and standard indexing 
provided by the databases is used. 

To create a new vocabulary property and add it to the vocabulary description, use 
code similar to this example: 

ESProperty newProp = new ESProperty ("Location" , "String", new 
ESValueC'BldgS") , true, true, ESConstants . N0_RANGE, 0, 0, 
ESConstants. NO_INDEX) ; 

printVocabDescription . addProperty (newProp) ; 
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ESServiceDescription 

The preceding example describes how a printer Vocabulary is defined. This 
Vocabulary description can be used by a standards body to register a Printer 
Vocabulary. Now, a printer manufacturer can choose to use this Vocabulary to 
advertise a printer with appropriate attribute values. 

For example, if a Printer Service provider were interested in offering an "Acme" 
printer as a Service, it can choose to describe the printer as follows: 

//describe printer in printervocab 

String propertyFileName = new String ( "/users/connection .prop" ) ; 
ESConnection core Connect ion = 

new ESConnection (propertyFileName) ; 
ES Vocabulary Finder printVocabFinder = 
new ESVocabularyFinder (coreConnection) ; 
ESQuery printVocabQuery = 

new ESQuery { "Name == x PrintVocab' " ) ; 
ESVocabulary printerVocab * 

printVocabFinder . find (printVocabQuery) ; 

ESServiceDescription printDescription = 

new ESServiceDescription (printerVocab) ,- 
printDescription . addAttribute ( "Manufacturer" , "HP" ) ; 
printDescription . addAttribute ( "Modelname" , "LP 5" ) ; 
printDescription.addAttributepDPI" , (int) 1400) ; 

Multi-Valued Attributes 

One of the new features in version 3.0 is support for multi-valued attributes in in- 
memory systems. This support allows the user to specify multiple values for a single 
service attribute. The following example deals with a printer that will accept several 
types of documents, including .pdf, .ppt, and .doc. The following commands set the 
printer's DocumentType attribute to accept multiple values: 

ESAttribute multiAttr = new ESAt tribute { "DocumentType" , new 

ESValue("DOC M ) ) ; 

// add additional values 

Object [] vals = new Object [3] ; 

vals[0] = "PDF"; 

vals[l] = "PPT"; 
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vals[2] = "XLS"; 
multiAttr .addValues (vals) ,- 
description . addAttribute (multiAttr) ; 

If the client uses any of these values to do a lookup, the service will be found by the 
client. For example: 

finder .find {vocab, new ESQuery ( "Document Type == 'DOC'"}); 
finder . find (vocab, new ESQuery ( "DocumentType == ' XLS 1 " ) ) ; 
finder . find (vocab, new ESQuery ( "DocumentType == ' PPT ' " ) ) ; 

All these queries will result in the service being found. This powerful feature can be 
used in cases where a service attribute may have more than one value as in the 
previous example. 

XML Descriptions of Services 

So far, APIs have been used to create and manage descriptions in Java. In addition 
to these APIs, J-ESI supports XML descriptions of Vocabularies and Service 

s using the constructors described here. XML is the preferred mode for describing 
Vocabularies and Services. Typically, XML is used for data descriptions passed as 
parameters to the description constructors. 

XML Vocabulary Description 

The ESVocabularyDescription class has a constructor that takes in an 
ESXMLFile describing the Vocabulary encapsulated in an XML page: 

public ESVocabulary (ESXMLFile xml_stream, ESConnection conn); 

This example creates a new Vocabulary with three attribute properties: 
Manufacturer, Modelname, and DPI: 

<?xml version^" 1 . 0" ?> 

<ESpeak version="E-speak 2.0" operation* "CreateVocab" 
xmlns="http: //localhost/e : /Esxml/Schemas/espeak.xsd" > 
<resource xmlns= ,r,, > 

<resourceDes xmlns=" "> 
<pattern> 

<Name xmlns=""> 
printervocab 
</Name> 
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<Type> 

Vocabulary 
</Type> 
</pattern> 
</resourceDes> 
<resourceData xmlns= " " > 

<attrGroup name="my printer Vocabulary" xmlns=" tr > 
<attrDecl xmlns=" " name= "Manufacturer" required= ll no" > 
<datatypeRef xmlns="" name= " string" /> 
</attrDecl> 

<attrDecl xmlns="" name="Modelnan\e" required="no"> 

<datatypeRef xmlns="" name= " string" /> 
</attrDecl> 

<attrDecl xmlns="" name="DPI" required- "no "> 
<datatypeRef xmlns="" name= " integer " > 
</datatypeRef > 
</attrDecl> 
</attrGroup> 
</resourceData> 
</resource> 
</ESpeak> 

All XML requests in e-speak have E-speak as the root element, which specifies the 
version information as well as the intended operation for the Services described in 
the request. As noted earlier, two aspects are required to describe Vocabularies. 

First, how Clients can find the Vocabulary has to be described. It is assumed that 
the Vocabularies are themselves defined in the default Vocabulary that allows 
specifying, among other things, the name and type of Service. In the preceding XML 
description, the element resourceDes specifies the Name of this Vocabulary to be 
printervocab. Because this is a Vocabulary, its Type is Vocabulary. 

Second, the properties of the Vocabulary must be specified. The properties that 
make up the printer Vocabulary are contained in an attrGroup element. The 
attrGroup element contains a list of attrDecl elements, each describing the 
specifics of an attribute property, including its name and data type. 

The XML file defines a Printer Vocabulary that has three properties: 

1 Manufacturer 

2 Model name 



3 



DPI. 
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As with queries, J-ESI 3.0 supports a new XML format for creating vocabularies. The 
new format involves constructing ESVocabularyDescription with two ESXMLFile 
arguments 

public ESVocabularyDescription (ESConnect ion connection, 
ESXMLFile xmlHeader, ESXMLFile xmlRequest) 

The contents of xmlHeader looks as follows: 
<?xml version^ ' I . 0 ' ?> 

< he ader xmlns= " ht tp : / / www . e - spe ak.net/ S enema / E - 
speak . header . xsd " > 

<communication> 

<to>es : //localhost : 12346/WebAccess/CreateVocab</to> 

< / c ommuni c a t ion > 
</header> 



The contents of xmlRequest looks as follows: 

<?xml version^ ' 1 . 0 1 ?> 

<resource xmlns= "http : // www . e- speak . ne t/Schema/E- speak . register . xsd" > 
<resourceDes> 

<vocabulary>http : / /www . e- speak .net /Schema/E- speak . base .xsd</ 
vocabulary> 

<attr name = ,f Name 11 > 

<value >pr intervocab< /value > 
</attr> 

<attr narae=" Type " > 

<value >Vocabulary< /value > 
</attr> 
</resourceDes> 

<attrGroup name= "printervocab" xmlns="http : / /www . e- speak .net /Schema/ 
E-speak . vocab.xsd" > 

<attrDecl name= "Model " reguired="true"> 

<datatypeRef name= "String" /> 
</attrDecl> 

<attrDecl name="DPI" required= " true " > 

<datatypeRef name="String ,, /> 
</attrDecl> 

<attrDecl name= "Manufacturer" required^ " true" > 

<datatypeRef name= "String" /> 
</attrDecl> 
</attrGroup> 
</ resource> 
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The ESServiceDescript ion class has a constructor that takes in an ESXML file 
describing the Vocabulary encapsulated in an XML page, as follows: 

public ESServiceDescription (ESXMLFile xmlDescriptionFile, 
ESConnection coreConnection) ; 

This is the recommended mode of creating and registering Services for 
compatibility with existing or emerging Vocabularies. The following example 
registers a new Service using the Vocabulary just created: 

<?xml version** "1.0"?> 

<ESpeak vers ion^'E- Speak l.Obeta" operation="RegisterService" 
xmlns="http: //localhost/e :/Esxml/Schemas/espeak.xsd M > 
<resource> 
<resourceDes xmlns= H " name=" Printer "> 
<!-- Specify printer Vocabulary --> 
<guery xmlns=" "> 

<gueryBlock xmlns=" "> 
< WHERE xmlns=" "> 

<!-- absence of query implies Base Vocabulary --> 
<condit ion xmlns= " " > 
<IN xmlns= ,,n > 

<pattern xmlns=""> 
<Name 

xmlns-" " >printervocab</Name> 
<Type 

xmlns=" " >Vocabulary</Type> 
</pattern> 
</IN> 
</condition> 
</ WHERE > 
</queryBlock> 
< /query > 

<!-- Begin: attributes --> 

<attrSet xmlns=""> 

<!-- End: Use printerVocabulary --> 

<attr xmlns= u " name= "Manufacturer" required="true"> 

<value xmlns= >HP</ value > 
</attr> 

<attr xmlns = nn name-" Mode lname" required="f alse" > 

< value xmlns =""> LP 5</value> 
</attr> 
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<attr xmlns= nn name= ,r DPI"> 

<value xmlns=" ">1400</value> 
</attr> 

<)-- End: attributes 
</attrSet> 
</resourceDes> 
</resource> 
</ESpeak> 

In the preceding example, XML has been used to describe a specific printer. The 
XML description has two parts. The first part of the XML document, the Vocabulary 
in which the rest of the description is to be interpreted, is specified. For example, 
the query specifies that the following description is in a Vocabulary whose name is 
printervocab: 

<?xml version="1.0"?> 

<ESpeak version- "E-Speak l.Obeta" operation="RegisterService" 
xmlns= "http : / /localhost/e : /Esxml/Schemas/espeak . xsd" > 
<resource> 
<resourceDes xmlns=" " name= " Printer" > 
<i-- Specify printer Vocabulary --> 
<query xrnlns^" 1 ' > 

<queryBlock xmlns=""> 

< WHERE xmlns=" "> 
<condition xmlns=""> 

<IN xmlns=" 11 > 

<pattern xmlns= ,!,, > 

<Name >pr intervocab< /Name > 
<Type>Vocabulary</Type> 
</pattern> 
</IN> 
</condition> 
</WHERE> 
</queryBlock> 
</guery> 

In the second part, the element at t rSet actually contains the set of attribute value 
pairs that describe the particular Service in question. The following example 
describes a printer whose Manufacturer is HP, whose Model name is LP 5 , and 
whose DPI is 1400: 

<?xml version= 1 1 . 0 ' ?> 

<resource xmlns= "http : //www. e-speak .net/Schema/E- 
speak . register . xsd" > 
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<resourceSpec> 

<locator> 
http://vAtfw.hp.com 

</locator> 
</resourceSpec> 
<resourceDes> 

<vocabulary> 
printervocab 
</vocabulary> 

<attr name= "Manufacturer" > 

<value >HP< /value > 
</attr> 

<attr name="Modelname"> 

<value>LP 5</value> 
</attr> 

<attr name="DPI"> 

<value>1400</value> 
</attr> 
</resourceDes> 
</resource> 

J-ESI does support the older XML schemas for registering services, but they should 
be treated like deprecated schemas and clients are encouraged to move to the 
newer schemas. The header for the service description creation looks as follows: 

<?xml version= 1 1 . 0 1 ?> 

<header xmlns="http: //www.e-speak .net/Schema/E- 
speak . header . xsd" > 
<communication> 

<to>es : / /localhost : 12346/WebAccess/RegisterService</to> 
< context > 

<}-- session token is inserted by the requesting appl . 
< /context > 
< / communication 
</header> 

The ESServiceDescription constructor that uses the new XML entry points looks as 
follows: 

public ESServiceDescription (ESConnection connection, 
ESXMLFile xmlHeader, 
ESXMLFile xmlReguest) 
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Example: Creating a Printer Description 

The following example shows how to make an XML description of a printer 
registered in the e-speak Core. This code assumes that a printervocab 
Vocabulary is found in the registry: 

String propertyFileName = new String ( "/users/connection .prop" ) ; 
ESConnection core Connect ion = new 
ESConnection (propertyFileName) ; 
ESXMLFile xmlDescriptionFile = 
new ESXMLFile ( w /users/printer .xml" ) ; 
ESServiceDescription printDescription = 
new ESServiceDescription (xmlDescriptionFile, 
coreConnection) ; 

where printer . xml is the XML file that has the contents in the last example. This 
is much more succinct than explicitly adding all the properties by hand. A typical 
usage scenario reads a list of products described in a merchant's catalogs, 
described in XML, to be read in and automatically registered as Services in e-speak. 

Now that various methods have been presented for describing Services, the next 
section describes other operations that Service providers have to perform to make 
their Service available to other Clients. 

Registering and Starting Services 

Typically, Service providers have to associate an actual implementation with their 
Service, register their Service, and start a handler that will handle requests directed 
to this Service. J-ESI provides an abstraction of a Service element represented by 
the ESServiceElement class for performing these operations. 

Consider the steps required to register a printer Service (PrinterServicelmpl) 
that implements the Print erServicelnt f . The following code fragment creates 
a Service described in the default Vocabulary with the name MyPr inter, registers 
it, and starts a thread that can process requests to the Service. The register ( ) 
call puts the description of the Service into the e-speak Repository so that other 
Clients can discover it. The start ( ) call starts a thread that processes requests to 
this Service. 

String propertyFileName = new String ( "/users/connection. prop" ) ; 
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ESConnection core Connect ion = new 
ESConnection {propertyFileName) ; 
ESXMLFile xmlDescriptionFile = 

new ESXMLFile ( u /users /printer .xml" ) ? 
ESServiceDescription printDescription = 

new ESServiceDescription (xmlDescriptionFile , 
core Connect ion) ; 
ESServiceElement printElement = 

new ESServiceElement (coreConnection, printDescription) ; 
printElement . setlmplementation (new PrinterServicelmpl ( ) ) ; 
ESAccessor printAccessor » printElement . register () ; 
printElement . start ( ) ; 

In this example, a single thread is started that handles the requests to the Service. 
All requests destined to this Service are dispatched to an instance of the 
PrinterServicelmpl object. 

There are situations where Clients may want to associate multiple Services with the 
same thread, or have multiple threads for the same Service. The current Client 
library allows Service providers to control the number of threads through the 
notion of a Service handler, represented by the ESServiceHandler class. 

Every connection with the e-speak Core has a default Service handler 
associated with it. This default Service handler can be retrieved using the 
getDef aultServiceHandler call in the connection, as shown by the following 
code fragment: 

String propertyFileName = new String ( -/users/connection .prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 
ESServiceHandler def aultHandler = 
coreConnection . getDef aultServiceHandler ( ) ; 

In essence, each Service handler encapsulates a channel of communication through 
which messages are received. A single Service handler can serve as a channel for 
getting messages to multiple Services. Each Service handler also has control over 
the number of threads that process the messages that are delivered on the 
communication channel. 

In the following example, a print server maintains a message queue for multiple 
printers. This is made possible by using the same handler for all the printers. The 
print server has 32 threads that process the requests of the Clients. The following 
code sample shows how this is accomplished: 
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String propertyFileName = new String ( "/users/connection . prop" ) ; 
ESConnection core Connect ion = new 
ESConnection (propertyFileName) ; 
ESServiceHandler printHandler = 

new ESServiceHandler (coreConnect ion) ; 
printHandler . setNumThreads (32) ; 

ESServiceDescription printDescriptionl = 

new ESServiceDescription () ; 
printDescriptionl . addAttribute ( "Name" , " Printerl" ) ; 
ESServiceElement printElementl = new 

ESServiceElement (coreConnect ion, printDescriptionl) ; 
printElementl. setlmplementation (new PrinterServicelmpl () ) ; 
printElementl . setHandler (printHandler) ; 
ESAccessor printAccessorl = printElementl . register () ; 
printElement 1. start () ; 

ESServiceDescription printDescription2 = 

new ESServiceDescription {) ; 
printDescription2 .addAttribute ("Name" , "Printer2" ) ; 
ESServiceElement printElement2 = 

new ESServiceElement ( coreConnect ion, printDescription2) ; 
printElement2 . setlmplementation (new PrinterServicelmpl ( ) ) ; 
printElement2 . setHandler (printHandler) ; 
ESAccessor printAccessor2 = printElement2 . register () ; 
printElement2 . start { ) ; 

The Service elements for each printer share the same handler. This way, there is a 
single queue for requests for both printers, and there are 32 threads that handle 
requests to the printers. 

Service-Specific Data 

As described earlier, Service-specific data is arbitrary data that can be associated 
with Services. Service-specific data comes in two forms: public and private. 

PublicData is data that can be accessed by any Client that can find the Service. 

PrivateData is data that is sent back to the Service handler along with each request 
to the Service. For example, this data can be used by the Service handler to 
distinguish among various Services that share this handler. 
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The following two API calls allow Clients to add public and private data to the 
descriptions: 

public void addPublicData (String dataName, byte [] data); 
This API call adds public Service-specific data to the Service element 

public void addPrivateData (String dataName, byte [] data); 
This API call adds private Service-specific data to the Service element 

For example, in a file system implementation, where the file store and the files 
themselves are Services, the file store may choose to identify the files it creates 
using private Data. This allows the file store to be very generic because it uses a 
flexible implementation for storing the bytes that make up a file. 

If the bytes are stored on the local disk directly, the file store can use the private 
Data to keep track of the directory path on the local disk for the file. If the file store 
instead stores the bytes making up a file in a database table, the information needed 
to access the row in the table where the bytes of the files are stored is in the private 
Data. 

This allows the file handler to determine where the bytes of the file are stored when 
a request for this file is received. The names for the data elements are selected by 
the creator of the Service based on need. Service creators can choose to associate 
multiple Data elements with every Service they create. 

Creating Services Described in Multiple Vocabularies 

In the current version of J-ESI, services can be advertised in multiple vocabularies. 
In essence, the ESServiceElement can be constructed with an array of service 
descriptions, each of which describes the service in one vocabulary. For instance, 
suppose that a printer service provider wanted to advertise the printer in two 
vocabularies. Suppose one of the vocabularies enabled the service provider to 
advertise the speed of the printer and the second allowed the service provider to 
advertise the printer quality measured in terms of the dots per inch (DPI). 
Furthermore, the properties that one can add to a vocabulary can be flagged as 
primary key properties so that the e-speak repository can build indices using such 
attributes. This allows the searches that use these properties to be quite efficient. 

ESServiceDescription sd[] = new ESServiceDescription [2] ; 
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try{ 

ESConnection connection = new ESConnection ( w f ile ,prN ; 

//Creating the vocabulary 

ESVocabularyDescription vocabDesc = new 
ESVocabularyDescriptionO ; 

ESVocabularyDescription vocabDescl = new 
ESVocabularyDescriptionO ; 

/ /Setting the vocabulary name 
vocabDesc . addAttribute ( "Name" , "vocab" ) ; 
vocabDescl .addAt tribute ( "Name" , "vocabl" ) ; 

//Adding vocabulary properties 

vocabDesc . addStringProperty ( "printerSpeed" ) ; 

vocabDescl . addStringProperty ( "printerDPI" } ; 

//Registering the vocabulary 

ESVocabularyElement vocabElem = new 
ESVocabularyElement {connection, vocabDesc) ; 

ESVocabularyElement vocabEleml = new 
ESVocabularyElement (connection, vocabDescl) ; 

ESVocabulary vocab = vocabElem. register () ; 

ESVocabulary vocabl = vocabEleml .register () ; 

ESServiceDescription sd = new ESServiceDescription [2] ; 

//Creating the service description 

sd[0] = new ESServiceDescription (vocab) ; 

sd[l] * new ESServiceDescription (vocabl) ; 

//Setting the service name 
sd[0] .addAttribute ("Name" , myPr inter" ) ; 
sd [0] . addAttribute ( "printerSpeed" , W 10" ) ; 
sd[l] .addAttribute ("Name" , "myPrinter" ) ; 
sd[l] .addAttribute ("printerDPI", "1000") ; 
//Create the service element 

ESServiceElement se = new ESServiceElement (connection, 
sd) ; 



Restarting Existing Services 

Just as Service providers can start new Services, J-ESI allows Service providers to 
restart existing Services. Clients may want to restart Services in order to resume a 
Service after recovering from a Service shutdown or outage. Clients can restart 
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Services in three ways: (i) They can construct a Service element from the 
description and call restart 0 on the element, (ii) they can store away the 
accessor for the service in a persistent folder and use the accessor to restart the 
service, or (iii) they can store away the accessor of the handler in a persistent folder 
and use that accessor to restart the service. Modes (ii) and (iii) are discussed in the 
next chapter in the section on folders. 

The element attempts to find a Service whose description matches the description 
currently provided in the element. If such a Service is found, it activates that Service 
so that requests to that Service are now handled. However, if no such Service is 
found, an exception occurs and the Client is expected to catch the exception and 
then register and start the Service. 

However, the recommended mode for restarting Services is with the use of Folders. 
The Client is expected to have created a local name for the Service in their folder 
hierarchy. See "Managing Bindings Using Folders" on page 91 to determine how to 
restart Services using the binding. 

The following example shows the typical use of the restart method without the use 
of Folders: 

public static void main (String [] args) 
try 

{ 

String propertyFileName = 

new String ("/users/connection. prop") ; 
ESConnection coreConnection = 

new ESConnection (propertyFileName) ; 
ESXMLFile xmiDescriptionFile = 

new ESXMLFile ( Vusers/printer .xml" ) ; 
ESServiceDescription printDescription = 

new ESServiceDescription 

(xmiDescriptionFile, coreConnection) ; 
ESServiceElement printElement - 

new ESServiceElement (coreConnection, printDescription); 
printElement . setlmplementation (new PrinterServicelmpl { ) ) ; 
ESServiceHandler printHandler = 

new ESServiceHandler (coreConnection) ; 
printHandler . se tNumThreads ( 2 ) ; 
printElement . setHandler (printHandler) ,* 
try 
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{ 

printElement. restart () ; 

System. out . print In { "XMLPrint Server re- started") ; 

} 

catch (ESLibRuntimeException ere) 

{ 

printElement . register ( } ; 
printElement . start ( ) ; 

System.out.println{"XMLPrintServer started") ; 

} 

} 

catch {Exception e) 

{ 

// handle the exception 

} 

} 



Registering Vocabularies and Contracts 

Vocabularies and Contracts are themselves Services that are registered with the e- 
speak infrastructure. However, the Service provider for Vocabularies and Contracts 
is the e-speak Core itself. Because of this, Clients who create Vocabularies only 
register them, and do not start a thread in order to serve requests to the Vocabulary 
or Contract. 

The classes that allow Clients to register Vocabularies and Contracts are 
ESVocabularyElement and ESContractElement , respectively. The 
following code fragment registers a printer Vocabulary that has three properties: 
DPI, 

Manufacturer, and Modelname: 

public class Vocabulary Creator 

{ 

public static void main (String [] argv) 

{ 

try 

{ 

String propertyFileName = 

new String { u /users/ connect ion. prop" ) ; 
ESConnection coreConnection - 
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new ESConnection(propertyFileName) ; 

ESVocabularyDescription print VocabDe script ion = 

new ESVocabularyDescription () ; 
print VocabDescription . addAttribute 

{ "Name" , "printervocab" } ; 
print VocabDescription . addlntegerProperty ( "DPI " ) ; 
printVocabDe script ion . addStringProperty ( "Manufacturer" ) ; 
printVocabDescript ion . addStringProperty ( "Modelname " ) ; 

ESVocabularyElement printVo cab Element = 
new ESVocabularyElement (coreConnection, 

printVocabDescription) ; 
ESVocabulary printVocab = printVocabElement * register () ; 

Property [] propertyList = printVocab .getProperties () ; 
for (int i - 0; i < propertyList . length; i++) 

{ 

System. out .println (propertyList [i] .getPropertyName () ) ; 

} 
} 

catch (Exception e) 

{ 

// handle the exception 

} 

} 

} 

Creating Contracts is very similar to the creation of Vocabularies. The following 
code fragment shows the creation of a simple Contract: 

public class ContractCreator 

{ 

public static void main (String [] argv) 

{ 

try 
{ 

String propertyFileName = 

new String ( u /users /connect ion. prop" ) ; 

ES Connect ion coreConnection = 

new ESConnection (propertyFileName) ; 
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ESContractDescription printContractDescription = 

new ESContractDescription () ; 
printContractDescription . addAttribute 

{ "Name" , " PrintContract " ) ; 

String printlDL =* getlDLFromFile { ) ; 
printContractDescription . setlnterf aceDef inition (printlDL) ; 

ESContractElement printContractElement = 
new ESContractElement (coreConnection, 
printContractDescription) ; 
ESContract printContract = printContractElement . register () ; 

String receivedPrintlDL = 
printContract . getlnterf aceDef inition { ) ; 

System. out .print In (receivedPrintlDL) ; 
} 

catch (Exception e) 

{ 

// handle the exception 

} 
} 

On registering a Vocabulary or Contract, the Clients receive a stub to the created 
Vocabulary or Contract. This is in contrast to other Services that the Client creates, 
where they receive an accessor to the Service that they create. (ESAccessor is 
explained in detail in the later sections) This is because the Client that is registering 
the Vocabulary or Contract is not the handler for that Vocabulary or Contract. 

A Bank Service Example 

The following example is a complete Bank Service example that makes use of many 
of the concepts introduced in this chapter. Figure 11 shows the relationship 
between a Bank Service, a Bank Service Contract, and the Bank Service Vocabulary. 
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Typically, the Bank Vocabulary, Bank Contract, and Bank Service are not defined 
by the same programmer; however, for the sake of simplicity in this example, we 
can assume that they are defined by the same person. 








rBank Service C ontract^VHNflHH 


WB^M|H Bank Service Vocabulary K| 











Conforms to 




Figure 1 1 Example of a Bank Service 



The following example lists the sequence of actions performed by a Bank Service 
(assuming the Vocabulary, Contract, and Service are all defined by the same piece 
of code): 

String propertyFileName = new String { w /users/connection .prop" ) ,* 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 
ESContractDescription bankContractDescription = 

new ESContractDescription () ; 
bankContractDescription . 

addAttribute { "Name" , "BankContract" ) ; 
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ESContractElement bankContract Element = 
new ESContractElement (coreConnection, 
bankContractDescription) ; 
ESContract bankContract = bankContractElement . register () ; 

ESXMLFile xmlDescriptionFile = 

new ESXMLFile P /users /bankVocab .xml" ) ; 
ESVocabularyDescription bankVocabDescription = new 
ESVocabularyDescription (xmlDescriptionFile , 
coreConnection) ,- 
ESVocabularyElement bankVocabElement = new 
ESVocabularyElement (coreConnection, 
bankVocabDescription) ; 
ESVocabulary bankVocab = bankVocabElement . register () ; 

xmlDescriptionFile = 

new ESXMLFile ( "/users /bank .xml" ) ; 
ESServiceDescription bankDescription = 

new ESServiceDescription (xmlDescriptionFile , 
coreConnection) ; 
bankDescription, setContract (bankContract) ; 

ESServiceElement bankElement = 

new ESServiceElement (coreConnection, bankDescription); 
bankElement . set Implementation (new BankServicelmpl () ) ; 
ESAccessor bankAccessor = bankElement . register () ; 
bankElement . start ( ) ; 

The following example shows the contents of the bankVocab . xml file that is used 
to describe the Vocabulary: 

<?xml version-" 1 . 0" ?> 

<ESpeak vers ion="E- speak 1.0" operation^' CreateVocab" > 
<resource> 

<i-- Begin: Specify the Vocabulary description --> 
<resourceDes> 
<attrSet> 

<attr name=' / Name' / > 

< value >bankvoc ab< /value > 
</attr> 
</attrSet> 
< / resourceDes > 

<!-- End: Specify the Vocabulary description --> 
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<resourceData> 

<!-- Begin: Specify the attribute property set --> 
<attrGroup name="Bank Vocabulary" > 
<attrDecl name="Name" > 

<datatypeRef name=" string" /> 
</attrDecl> 

<attrDecl name="createAccount" > 

<datatypeRef name=" string" /> 
</attrDecl> 

<attrDecl name =" trades tock" > 

<datatypeRef name=" string" /> 
</attrDecl> 
</attrGroup> 

<!-- End: Specify the attribute property set --> 
</resourceData> 
</resource> 
</Espeak> 

The following example lists the contents of the bank . xml file that is used to 
describe the particular Bank Service: 

<?xml version="1.0" ?> 

<ESpeak version="E-Speak 1.0" operation="RegisterService"> 
<resource> 

<resourceDes name="Bank Description" > 

<!-- Begin: Specify bank Vocabulary in a query--> 
<query> 

<queryBlock> 
< WHERE > 

<condition> 
<IN> 

<pattern> 

<Name >bankvocab< /Name > 
</pattern> 
</IN> 
</condition> 
< /WHERE > 
</gueryBlock> 
</query> 

<J-- End: Specify bankVocabulary --> 
<J-- Begin: the attribute list --> 
<attrSet> 

<i-- End: Use bank Vocabulary --> 

<attr name =" Name "> 
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< value >Acme< /value > 
</attr> 

<attr name =" ere a teAc count" > 

<value type=" string" >"Acme l"</value> 
</attr> 

<attr name="tradeStock"> 

< value type=" string" >"hwp"< /value > 
</attr> 
</attrSet> 

<i-- End: the attribute list --> 
</resourceDes> 
</resource> 
</ESpeak> 



Accessing Descriptions: ESAccessor 

ESAccessor is a reference to a Service with which the user can do the following. 

• Obtain or change the attributes of a Service 

• Send messages to the Service (More details are in Appendix B) 

Typically, a Client finds a Service that matches some desired attributes, but after 
finding the Service, the Client may be interested in checking the values of other 
attributes as well. 

For example, a Client may find a list of printers meeting a certain DPI value, but 
after finding this list, the Client may want to determine the manufacturer name 
before proceeding further. In such situations, the Client can get the accessor for 
each Service and query the accessor for the manufacturer attribute's value. 

Similarly, an administrator who manages the printer may want to mutate one of the 
searchable attributes or add new Data to reflect some upgrade to the printer. In this 
case, the ESAccessor is used to mutate the Service description as well. For 
example: 

String propertyFileName = new String { "/users/connection .prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 
ESXMLFile xmlDescriptionFile = 
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new ESXMLFile( Vusers/printerQuery.xml") ,* 
ESXMLQuery printQuery = new ESXMLQuery (core Connect ion, 

xmlDescriptionFile) ; 
ESServiceFinder printFinder = new 
ESServiceFinder (core Connect ion) ; 

ESService printService = printFinder . find (printQuery) ; 
ESAccessor printAccessor = 

( (ESAccessorHandle) printService) .getAccessor ( ) ; 

On the Service provider side, when a Service is registered, an accessor is returned 
as a result of doing the register call. For example: 

String propertyFileName = new String ( "/users/connection .prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 
ESServiceDescription printDescription = 

new ESServiceDescription (printVocab) ; 
printDescription . addAttribute ( "Modelname" , "HP1000" ) ; 
ESServiceElement printElement = 

new ESServiceElement (coreConnection, printDescription) ; 
printElement . setlmplementation (new PrinterServicelmpl ( ) ) ; 
ESAccessor printAccessor = printElement .register () ; 
printElement . start ( ) ; 

The Service provider can now use the accessor to access and mutate the description 
of the Service. 

Consider a printer Client who, after finding a printer with DPI 1400, decides 
to list all the attributes of the printer, perhaps in an effort to find out its 
manufacturer, speed, and so on.: 

String propertyFileName = new String ( » /users/connection .prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 
ESServiceFinder printFinder = 
new ESServiceFinder (coreConnection) ; 
ESQuery printQuery = new ESQuery (print ervocab) ; 
printQuery. addConstraint ( "DPI==14 00" ) ; 
ESService printService = printFinder . find (printQuery) ; 
ESAccessor printAccessor = 

( (ESAccessorHandle) printService) .getAcessor {) ; 
System. out. print In ("Attributes of this printer are;\n") ; 
ESAttribute [] attrList =printAccessor . getAttributes ( ) ; 
for(int i=0; i<attrList . length; i++) 
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{ 

^ System, out .println (attrList [i] .toStringO ) ; 

A Service provider who has created a Service or a Client and who has the 
appropriate permissions can change the attributes of the Services. For example, if 
the administrator upgrades the printer to the latest model that supports a higher 
DPI, the administrator can update the description of the printer with the new values 
for the attributes as follows: 

/ / code to find print service from above 

String proper tyFileName » new String ( "/users/connection. prop" ) ; 
ESConnection core Connect ion = new 
ESConnection(propertyFileName) 
ESVocabularyFinder printVocabFinder = 

new ESVocabularyFinder (core Connect ion) ; 
ESQuery printVocabQuery = 

new ESQuery ( "Name * print ervocab '") ; 
ESVocabulary printVocab = 
printVocabFinder . find (printVocabQuery) ; 

ESQuery printQuery = new ESQuery ( "Manufacturer ^= "HP"'); 
ESService printService = printFinder . find (printQuery) ; 
ESAccessor printAccessor = 

( (ESAccessorHandle) printService) .getAccessor ( ) ; 

ESAttribute attrl = new ESAttribute ( "Manufacturer" ) ; 
attrl . setValue { tt HP" ) ; 

ESAttribute attr2 = new ESAttribute ( "DPI" ) ; 
attrl. setValue ( (int) 1400) ; 

printAccessor. setAttribute (attrl, printVocab) ; 
printAccessor. setAttribute (attr2, printVocab) ; 

The ESAccessor class also has other methods that can be used to mutate the 
metadata of services. Examples of such methods are the following. Note that 
though some of these signatures refer to ESBaseDescription, in practice, these 
return values or arguments to these functions are instances of 
ESVocabularyDescription, ESContractDescription, ESViewDescription, 
ESServiceDescription, etc. 

public void setDescriptions (ESBaseDescriptions [] desc) ; 
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public void setDescription (ESBaseDescription desc) ; 
public void setAttribute (ESAt tribute attr, ESVocabulary vocab); 
public void setAttributes {ESAttribute [] attrs, ESVocabulary 
vocab) ; 

public ESBaseDescription [] getDescriptions { ) ; 

public ESBaseDescription getDescription ( ) ; 

public ESAttribute getAttribute (String name, ESVocabulary 

vocab) ; 

public ESAttribute [] get At tributes (String name, ESVocabulary 
vocab) ; 
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The previous chapters described the programming model, and how e-speak Clients 
and Services interact. In addition to support for these basic functions, J-ESI 
supports extended Services that enable support for persistent bindings, Event- 
based interaction semantics, and loosely coupled distributed Communities. This 
chapter shows how these extended Services can be used to create sophisticated 
Service interactions. 

The chapter is divided into the following sections: 

• Managing Bindings Using Folders 

• Repository Views 

• Categories 

• Communities 

• Security 

• Events 



Managing Bindings Using Folders 

One of the main reasons why e-speak can support loosely coupled distributed 
Services is that it does not rely on global naming. In many traditional distributed 
systems, the distribution is possible because Clients know the name of the Service 
providers and they use the name to access the Service. 
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In e-speak, on the other hand, there are no global names. Clients can make up names 
for the Services they find or create, and that name is independent of the name that 
another Client uses for the same Service. 

For instance, one Client may refer to a Printer Service as "Marketing Printer," while 
another Client may refer to the same Printer Service as "Engineering Printer." This 
allows Services to be migrated or upgraded, without having to change the Client- 
side programs that use these Services. Figure 12 illustrates the naming process in e- 
speak. 



Figure 12 Example of folder names using e-speak 

In J-ESI, Clients manage their local name spaces using folders. Folders are 
analogous to directories in traditional file systems. Clients can create bindings 
between the names and Services they find and then put the bindings in a folder. 

Essentially, folders enable Clients to build a local hierarchical name space. Every 
user account in an e-speak Core has a folder that is its root (typically denoted by /). 
Clients can get at the root folder in their session by invoking the getRootFolder 
method in ESConnection. For example: 

String propertyFileName = new String ( "/users/connection .prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 

ESFolder myRoot = coreConnection . getRootFolder () ; 
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Creating Folders 

Folders created by Clients are either persistent or transient. A transient folder is a 
folder that does not survive beyond the lifetime of the connection in which it is 
created. A persistent folder, on the other hand, can survive beyond the lifetime of 
the connection in which it is created. If the Core is backed up in a database, 
persistent folders also survive Core reboots. This is because, although the folders 
are a Client-side abstraction, their state is maintained in the e-speak Core. 

Creating Transient Folders 

Currently, Clients can create transient or persistent folder hierarchies under the 
root folder. To create a transient folder hierarchy, they create a subfolder of the 
root folder that is transient. For example, to create a transient folder under the root 
folder called bookmarks, use the following constructor of ESFolder: 

String propertyFileName = new String { "/users/connection .prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 

ESFolder bookMark Folder = new ESFolder (coreConnection, 
"bookmarks" ) ; 

This call creates a transient folder under the root folder called /bookmarks. The 
folder constructor is used to create subfolders of the root folder, while the 
createSubFolder method is used to create subfolders of all non-root folders. 

Creating Persistent Folders 

The above ESFolder constructor cannot be used to create persistent folders. To 
create a persistent folder called /myServices under the root folder, the following 
call is used: 

String propertyFileName = new String ( "/users/connection .prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 

ESFolder ownFolder = new ESFolder (coreConnection, "myServices" , 
true) ; 
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By default, a root folder is persistent. Hence, the user invokes the 
createSubFolder method on the root folder to create persistent folders. 
Because the folder /myServices is a persistent folder, any subfolder of / 
myServices is also persistent. 

As in most operating systems, there is the idea of a current folder in J-ESL Clients 
can get their current folder through the Service context, as shown by the following 
code fragment: 

String propertyFileName = new String ( "/users/connection. prop" ) ; 
ESConnection core Connect ion = new 
ESConnection (propertyFileName) ; 
ESServiceContext connectContext = 

coreConnection.getServiceContext {) ; 
ESFolder currentFolder = connectContext . getCurrentFolder () ; 

When a new connection is created, the name of the home folder is read from the 
properties file that is passed to the constructor of ESConnection. The value of the 
property named home folder in the properties file is used as the name of the home 
folder. If no properties file is passed to the constructor of ESConnection, the 
default home folder is /home. The home folder can be obtained as follows: 

String propertyFileName = new String ( "/users/connect ion. prop" ) ; 
ESConnection coreConnection - new 
ESConnection (propertyFileName) ; 

ESFolder homeFolder = coreConnection .getHomeFolder () ; 

The properties of the current folder that the Client is located in are important. If a 
Client creates Services while in a persistent folder, the Service is created as a 
persistent Service. This means that the description of the Service is registered with 
the e-speak Core even if the handler of the Service disconnects from the e-speak 
Core. 

Naming Found Services 

Clients typically create folders to manage name bindings on Services they have 
discovered or created. For example, an administrator may add bindings to 
discovered print Services in a persistent folder (such as /home/ services/ 
printers). Because the bindings are stored in a persistent folder, anytime the 
administrator reconnects, they continue to have access to previously discovered 
printers by simply looking into the persistent /home/printers folder. 
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The following code fragment shows the creation of a subfolder 1 printers ' of the 
Client's home folder (/home/services). After printers is created, the Client 
finds a printer and places a name binding for it in this folder. 

String propertyFileName = new String ( M /users/ connection . prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 
ESServiceContext connect Context - 

coreConnection. getServiceContext () ; 
ESFolder currentFolder = connectContext .getCurrent Folder () ; 
// The current folder is assumed to be /home/services. 
// This can be set in the properties file 
ESFolder newFolder = null; 
try { 

newFolder - currentFolder . getSubFolder { "printers" ) ; 

} 

catch (InvalidNameException ine) { 
newFolder = currentFolder . createSubFolder ( "printers" ) ; 

} 

connectContext . setCurrentFolder (newFolder) ; 

PrinterServicelntf printer = null; 

try{ 

printer = (PrinterServicelntf) 

newFolder .getService ( "mypr inter" , "PrinterServicelntf " ) ; 

} 

catch (ESInvocationException esie) { 

ESXMLFile xmlQueryFile = new ESXMLFile ( "/users/ 
printerQuery .xml" ) ; 

ESXMLQuery printQuery = 

new ESXMLQuery (coreConnection, printQuery) ; 

String intfName = PrinterServicelntf . class .getName () ; 

ESServiceFinder printFinder = 

new ESServiceFinder (coreConnection/ intfName); 

printer = (PrinterServicelntf) printFinder . find (printQuery) ; 

newFolder . add ( "myprinter" , printer) ; 

} 

/ / get the contents of the folder 
StringH contents = newFolder . listNames () ; 
Naming Created Services 

Naming a Service which is created and adding it to a folder is 
similar to naming a found Service. The following code shows an 
example of how to name a created Service. 

String propertyFileName - new String ( w /users/connection .prop" ) ; 
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ESConnection coreConnection = new 
ESConnection (proper tyFileName) ; 
ESServiceContext connect Context ~ 

coreConnection. getServiceContext () ; 
ESFolder currentFolder = connectContext .getCurrentFolder () ; 
// The current folder is assumed to be /home/services. 
// This can be set in the properties file 
ESFolder newFolder = null; 
try { 

newFolder = currentFolder .getSubFolder ( "printers" ) ; 

} 

catch (InvalidNameException ine) { 
newFolder = currentFolder . createSubFolder ( "printers " ) ; 

} 

connectContext . setCurrentFolder (newFolder) ; 
if ( I (newFolder . containsName ( w f as tpr inter" ) ) { 

ESXMLFile xmlDescriptionFile = 

new ESXMLFile ( "/users /printer. xml" ) ; 
ESServiceDescription printDescription = 

new ESServiceDescription {xmlDescriptionFile , 
coreConnection) ; 
ESServiceElement printElement = new ESServiceElement ( 

coreConnection, printDescription) ; 
printElement . setlmplementation (new PrinterServicelmpl { ) ) ; 
ESServiceHandler essh = new ESServiceHandler (coreConnection) ; 
printElement . setHandler (essh) ; 

ESFolder homeFolder = coreConnection. getHomeFolder () ; 
homeFolder . add (HANDLER_NAME , essh .getAccessor ( ) ) ; 
ESAccessor printAccessor = printElement . register () ; 
printElement . start ( ) ; 

newFolder .add ( tt fas tpr inter", printAccessor) ; 

} 

else 

{ 

ESServiceElement printElement = new 

ESServiceElement (newFolder .getAccessor ( w f astprinter") ) ; 

printElement . setlmplementation (new PrinterServicelmpl () ) ; 
printElement . restart { ) ; 

} 

When the Service provider goes off-line and logs back into the e-speak Core, they 
do not have to re-create the Service. The provider looks for the name binding 
corresponding to the printer that they created and performs a restart. This allows 
the print Service to go online and to respond to requests. 
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An alternative way to restart services is to use the accessor of the service handler, 
A service provider can store away a binding to the service handler that was created 
to handle requests to her services in a folder. On restarting, the service handler can 
be recreated from this binding, and a service element can be recreated from the 
service handler. This allows multiple services that share a handler to be restarted 
without creating a service element for each service all over again. The following 
code snippet shows how to do this. 

ESConnection conn = new ES Connect ion ( "propfile" ) ; 
ESFolder home - conn . get Home Folder { ) ; 

ESAccessor da = home . get Accessor (HANDLER_NAME) ; 
ESServiceHandler handler = new ESServiceHandler (da) ; 
handler . setNumThreads (numThreads) ; 
ESServiceElement element = new 
ESServiceElement (handler) ; 

element . setlmplementation (new PrintServicelmpl ( ) ) ; 
element . restart ( ) ; 



Creating and Finding Folders with Descriptions 

Clients can create folders and describe them in any Vocabulary just like any other 
Service. By doing this, the folders can be found by other Clients using the queries 
that are in the Vocabulary in which the folder was advertised. Creating the folders 
with descriptions allows other Clients to discover the folders and use the name 
bindings that have been created within the folders. 

For example, if Client A creates a folder with bindings for print Services that they 
want to share with Client B, Client A can create the folder with a description and 
advertise it so that Client B can discover the folder. Client B can then use the 
bindings without also having to create their own bindings. 

Some of the constructors of ESFolder, as well as some of the createSubFolder 
calls in ESFolder, take an additional ESServiceDescription that describes 
the attributes of the folder that is being created. For example: 

String propertyFileName - new String { "/users/connection .prop" ) ; 
ESConnection coreConnection = new 
ESConnection (propertyFileName) ; 
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ESXMLFile xmlDescriptionFile = new ESXMLFile ( V^sers/ 
f older. xml") ; 

ESServiceDescription f olderDescription = 

new ESServiceDescription {xmlDescriptionFile, coreConnection) ; 
ESFolder newFolder = new ESFolder { "services" , 
folderDescription) ; 

The preceding constructor of ESFolder causes the description of the folder to be 
registered in the Repository of the Core so that other Clients can discover the folder 
description. Folders are found using the ESFolderFinder class. For example: 

String proper tyFileName = new String < w /users/connection .prop" } ; 
ESConnection coreConnection - new 
ESConnection (proper tyFileName) ; 

ESFolderFinder f Finder = new ESFolderFinder (coreConnection) ; 
ESXMLFile xmlQueryFile = 

new ESXMLFile { "/users/ folderQuery .xml" ) ; 
ESXMLQuery folderQuery = 

new ESXMLQuery (coreConnection, xmlQueryFile); 
ESFolder folder = f Finder . find (folderQuery) ,* 



Navigating Folders 

The ESFolder class has methods for navigating a folder hierarchy. For example, 
to get the subfolder of a given folder, there is a getSubFolder call. On the other 
hand, to get the parent of any folder, a getParent call is issued. In addition, there 
are other calls that allow the Client to list the contents of the folders. 

Scopes 

Scopes are used to mark the lifetime of transient and persistent Services. 

Before scopes can be used, boundaries need to be defined for them. The following 
method in ESServiceContext is used to signify scope boundaries: 

public void beginTransientScope ( ) ; 
public void endTransient Scope ( ) ; 
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Ending a scope results in all the transient/persistent Services created in the scope 
being deleted. Furthermore, all the transient bindings for Services found by the 
Client are also deleted. For example: 

String propertyFileName = new String ( "/users/connection .prop" ) ; 
ESConnection coreConnection = new 
ESConnect ion (propertyFileName) ; 
ESServiceContext connectContext « 
coreConnection. get ServiceContext () ; 

while (notDone ( ) } 
{ 

connectContext .beginTransientScope ( ) ; 
createFindAndUseServices (coreConnection) ; 
connectContext . endTransientScope ( ) ; 

In this example, the createFindAndUseServices is a method that creates and 
uses a transient Service. The end scope call following this method invocation 
automatically deletes all transient bindings and Services created in the method. 



Repository Views 

The repository view is a feature in e-speak that allows clients to restrict the scope 
of their searches to within the view. These views are collections of e-speak 
registered e-speak services. Clients can add and remove services from these views. 
These views are maintained by the e-speak core engine, therefore they are core- 
managed services. These repository views are described using ESViewDescription 
just as vocabularies are described with ESVocabularyDescription and other 
services are described with ESServiceDescription. Similarly, clients use the 
ESViewFinder to find these repository views and create ESViewElement instances 
in order to register new repository views with the core repository. 

The following code snippet shows how a client can create a repository view, find it, 
and add elements to it, etc. 



Developer Release X.03.03.00, September 2000 



99 



Restricting searches with views 



Extended Services 



public class testView 
{ 

public static void main (String args [] ) 

ESConnection es = null; 
try { 

String propertyFileName = new String ( "/users/ 
c onnect ion. prop " ) ; 

es = new ESConnection (propertyFileName) ; 

ESViewDescription esd = new ESViewDe script ion ( ) ; 

esd.addAttribute ("Name" , "TestView") ; 

ESViewElement ese = new ESViewElement {es, esd) ; 

ESView v = ese. register () ; 

ESViewFinder esf = new ESViewFinder (es) ; 

ESView [] ess = esf . f indAll (new ESQuery ( "Name == 
'TestView' ") ) ; 

ESAccessor esa = ( (ESAccessorHandle) ess [0] ) .getAccessor ( ) ; 
( (ESViewStub)ess [0] ) .add (esa) ; 
boolean result = false; 

result = ( (ESViewStub) ess [0] ) . contains (esa) ; 

// get all the accessors in the view 

ESAccessorf] e= { (ESViewStub) ess [0] ). list () ; 

es. close () ; 
} catch (Exception e) { 
} 
} 

} 



Restricting searches with views 

The typical use of such repository views is to restrict the search results from 
queries. This is accomplished by associating a view with a query. When an ESQuery 
with an associated view is executed by the e-speak repository, the search results 
are guaranteed to be from the elements within the repository view. 

String propertyFileName = new String {" /users/connection .prop" ) ; 
ESConnection es = new ESConnection (propertyFileName) ; 

System.out .println( "Connected to core"); 
ESViewFinder esf = new ESViewFinder (es) ; 
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ESView view = esf . find (new E S Que ry { "Name — 1 myPrintView ' " ) ) ; 
ESServiceFinder finder = new ESServiceFinder (es , 
"PrinterServicelntf " ) ; 

ESVocabulary pVocab = // . . code to find vocabulary 
ESQuery query = new ESQuery (pVocab, "printerSpeed == *10"'); 
query . set View (view) ; 
try { 

ESService[] list = f inder. findAll (query) ; 
for (int i - 0; i < list. length; i++) { 

ESServiceStub printer = (ESServiceStub) list [i] ; 

ESAccessor desc = f ile .getAccessor () ; 

} 

} 

catch (LookupFailedException lfe) { 

// No entries were found that matched the search criteria 

} 



Categories 

J-ESI supports the notion of categories. These categories provide a way to classify 
services so that service providers can advertise in multiple categories and clients 
can find services of interest to them in the categories of interest to them. Each 
category is qualified by its name. Furthermore, one can create sub-categories of 
existing categories, and provide descriptions for them. When clients search for 
services, they too can set the categories that they want the search to be performed 
in. This becomes part of their query and picks out the services that are advertised 
in the categories of interest to the client. 

The category list of interest to the client/service provider is maintained in the 
ESServiceContext that is associated with the ESConnection. The following 
example shows the registration of the print service in the "high speed printer" 
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category. Essentially, the service provider sets the current category list in the 
ESServiceContext and these categories are used when registering and advertising 
the service. 

public static void main (String [] args) 
{ 

try { 

String propertyFileName = new String (" /users/ 
connection. prop" ) ; 

ESConnection connection = new 
ESConnection (propertyFileName) ; 

ESCategoryFinder cf = new ESCategoryFinder (connection) ; 

ESCategory root = cf . f indRootCategory () ; 

ESCategory catl « root . createCategory ("high speed printer", 
"high ppm") ; 

ESCategory [] catList = new ESCategory [2] ; 
catList [0] = root; 
catList [1] = catl; 

connect ion. getServiceContext () . setCategory{ catList) ; 
ESServiceDescription sd = new ESServiceDescription ( ) ; 
sd.addAttribute { ES Const ant s . SERVICE_NAME, "printer") ; 
sd.addAttribute ("Description" , "my hp printer"); 
ESServiceElement se = new ESServiceElement (connection, sd) ; 
se . set Implementation (new PrinterServicelmpl ( ) ) ; 
se . register ( ) ; 
se .advertise () ; 
se . start ( ) ; 

} catch (Exception el) { 
} 

} 

Now, on the client side, the finder for the printers also uses the category list that is 
set in the service context. The code snippet below shows how to search for printers 
in the "high speed printer" category. Note that the client has to construct a category 
list that represents the path from the root category to the category of interest. 

public static void main (String [] args) { 
try { 

String propFileName = args [13; 

ESConnection connection = new ESConnection( propFileName ); 

ESCategoryFinder cf = new ESCategoryFinder (connection) ; 
ESCategory root = cf . f indRootCategory {) ; 
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ESAccessorH catlAcc = cf. find {"high speed printer"}; 
ESCategory catl = new ESCategory Stub (connection, catlAcc[03); 
ESCategory!] catList » new ESCategory [2] ; 
catListEO] = root; 
catList[l] = catl; 

connect ion. getServiceContext {) . setCategory{ catList) ; 

ESQuery q = new ESQuery ( ES Const ant s .SERVICEJJAME + 
"==» printer'") ; 

ESServiceFinder sf = new ESServiceFinder (connection, 

"PrinterServicelntf") ; 

ESService[] myObjs * sf . f indAll <q) ; 

if(( myObjs null ) || (myObjs . length == 0)) 

System. out. print In { "ERROR IN CREATING STUB/FINDING" ); 
System. out. print In ("Found " + myObjs .length + " services"); 

for(int i=0; i<myObjs . length; i++) { 
PrinterServicelntf myObj = 

(PrinterServicelntf ) myObjs [i] ; 
String junk = myObj .print 0 ; 

connection. close ( ) ; 
return ; 
} catch (Exception el) { 

} } 

Delegators 

Often, there is a need for the implementation objects associated with services to 
have access to some of the metadata of the services that the implementation object 
is associated with. For example, a file implementation is to be shared amongst 
multiple files that are registered as services with e-speak. Suppose furthermore, 
that the private service specific data is used to store the actual path to the contents 
of the file on disk. In particular, suppose that the name of the service specific data 
is "RealFileName". Essentially, when the implementation object extends the 
ESDelegatorlmpl, the service specific data of the service is passed onto the 
implementation object. This allows the implementation object to determine the 
exact service for which this request is meant. 

public class VFSFilelmpl extends ESDelegatorlmpl { 
final static String REAL_FILE_NAME = "RealFileName " ; 
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public VFSFilelmpl (ES Connect ion connection, ESVocabulary vocab, ESLogClient 
log, 

int numThreads) { 

// constructor. . . . 

} 

public byte[] f etchBuf f er (int offset, int size) 
throws ESlnvocationException { 
try { 

String fileName = getFileName { ) ; 
File file = new File (fileName) ; 
int count = size; 

int whatsLeft = (int) file. length {) - offset; 

if (whatsLeft < count) { 
count = whatsLeft; 

byte [] fileBuffer = new byte [count] ; 

FilelnputStream in = new FilelnputStream (f ile) ; 

in. skip ( (long) of f set) ; 

in. read (fileBuffer) ; 

in. close { ) ; 

return fileBuffer; 
} catch (Exception ioe) { 
} finally { 
} 

} 



private String getFileName ( ) { 
try { 

byte[] entry = getPrivateData (REAL_FILE_NAME) ; 
String fileName = new String (entry) ; 
return fileName; 
} finally { 

} 

} 

} 
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So far, the discussion has focused on how e-speak Clients can register and discover 
new Services while using folders to manage Service bindings. No mention has been 
made yet of multiple connected Cores, the distributed nature of deployments, or the 
impact of distribution on failure semantics, latency, and concurrency. 

J-ESI makes it easy for programmers to write distributed Services. Although all 
Services are registered in the local Core by default, these can be made more widely 
visible by advertising this Service across multiple Cores. In J-ESI, the possible 
domains in which a Service is visible are as follows: 

• Only the e-speak Core — In this deployment scenario, all Clients that want to 
use this Service are also connected to the same Core, loosely representative of 
a classic Client-server deployment of Services. 

• In an e-speak group — An e-speak group is a collection of e-speak Cores that are 
closely connected to each other, such as in an administrative domain. These 
Cores typically can find all Services registered in any of the other Cores, and 
they may all share the same back-end server (possibly an LDAP server) for 
storing all Services registered in the group. E-services Village, a HP hosted 
service directory is an example of such a service directory. Such deployments 
are analogous to lookup or naming servers used in other solutions. Note: The 
advertising services without LDAP should use the same group name in the 
command line -group <groupname> option if they want to be part of the same 
group. 

• In an e-speak community— An e-speak community is a Client-defined named 
set of e-speak groups that is created by Clients to enable them to search through 
different related sets of Services easily. The default community in J-ESI includes 
www.eservicesvillage.com. Therefore, every query that any client executes 
returns results that are not only in the local core, but also in eservices village. 

In Figure 13, the top left corner shows a single Core case where all Clients and 
Service providers are connected to the same Core. The top right corner shows an e- 
speak group in which a closely connected group of Cores share an LDAP server or 
use other mechanisms to advertise all their Services to each other. The bottom 
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figure shows an e-speak community that can be formed between groups A and B. A 
Client in group A can select to find Services in group B, by setting the community 
list to include group B. 




Figure 1 3 E-speak Core groups 

A Service provider can advertise the Service in the local advertising service or can 
advertise it to different groups. The Service provider can do so by using either the 
advertise call or advertiselnOtherGroups method in 
ESServiceElement * 

Consider an example where there are a number of printers organized according to 
administrative groups. Additionally, assume that each administrative group is 
associated with a different e-speak group. A user wanting to find printers across all 
administrative groups but still located closest to the user performs the following 
steps: 

1 Create their own community that lists the groups of all the relevant 

administrative domains. Each group is identified by a string with the following 
format: 



Developer Release X. 03. 03. 00, September 2000 



Extended Services 



Communities 



<host_name> : <port_num>/<group_name> 

The host name and port number identify the host machine in which an advertis- 
ing Service for the group of interest can be found. In addition, the name of the 
group of interest is specified as well. Note: The port is that of the connection 
factory and not of the Core. The advertising service should have been started 
with the same group name, with the command line option -group <group- 
name>. 

ESCommunity newCommunity = new ESCommunity (core Connect ion) ; 
newCommunity.add( tt hostl :22020/auction_sitel" ) ; 
newCommunity. add { tt host2 :22021/auction_site2" ) ; 

Another way to create a community is to specify it in the properties file used on 
start-up. The properties file takes in a community property that is a comma- 
delimited list of groups such as: 

printcommunity .prop file: 
community = hostl : 22020/auction_sitel, host 2 : 22021/auction_site2 

2 Set the current community to this community name using the 
ESServiceContext class: 

ESServiceContext connectContext = 

coreConnection.getServiceContext () ; 
connectContext . setCommunity (newCommunity) ; 

3 Perform a search as follows: 

ESServiceFinder anyFinder = 

new ESServiceFinder (coreConnect ion) ; 
anyFinder . find ( "Name == x AnyService ' " ) ; 

A mobile user can simply switch the community profile to find the appropriate 
Services in the currently relevant community. 

In fact, because e-speak is geared toward Service deployment, it is natural to 
simplify the process of advertising a Service across a wide geographical area, 
simplify searching, and provide distributed access control. 
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To simplify the programming of distributed Services, the following support is built 
into J-ESI: 

• Advertising a Service automatically makes the Service visible to the group in 
which it has been advertised. 

• Because each Core has a registry, an e-speak deployment does not require a 
centralized naming or lookup Service to obtain information about all Services 
registered. A centralized scheme can be implemented as a special case within a 
more general scheme enabled by e-speak finder Services. The search for a 
Service is automatically performed in parallel across multiple registries. 

Advertising across internet and locally 

Advertising service across the Internet using HP hosted global service 
directory 

Service providers can advertise the services throughout the world using HP hosted 
global service directory by selecting default values when starting the advertising 
service. In this case, when user invokes the advertise 0 call, the service gets 
advertised in the global service directory. This allows a service provider located in 
Los Angles to advertise a service to the global directory, accessible by any clients in 
New York. Clients and service providers can use the hosted gateway/connector 
service at eservicesvillage.com to access and provide services from behind a 
firewall. 

For services hosted behind a firewall to advertise themselves at 
eservicesvillage.com (or any other service directory on the internet), the service 
provider has to set up the configuration files appropriately. The sections of the e- 
speak configuration file that pertain to web-proxy configuration and advertising 
service configuration may have to be modified in order for this to work correctly. 
The following is a sample section from an e-speak configuration file with the rules 
for web-proxy and advertising service configuration. 



Web proxy configuration 

webproxyname is a single value being the fully qualified hostname 
of the http -proxy used to traverse a firewall 
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net . espeak . infra . core . connector . webproxyname=web- proxy . ef gi j k . com 

! webproxyport is the port on which the proxy listens 
net .espeak. infra. core. connector .webproxyport =8 08 8 

! domain for which direct connection should be done. 
I only one entry is supported currently 
! Syntax is the end of the domain that should be match 
I the '*' wildcard is not supported. 

net . espeak . infra . core . connector . noproxydomain= ef gi j k . com 



Advertising Proxy configuration 



I host at which the core for advertising proxy is running 
net . espeak . services . advertise . esv_proxy_host-XXXXXXXX 
(needs to be fixed*****************************************) 

Iport at which the core for advertising proxy is running 
net . espeak . services . advertise . esvj?roxy_j>ort=2 3456 

[default username and password to be used at the e-services village 
net . espeak . services . advertise . esv_user_name=%esv_username% 
net . espeak . services . advertise . esv_password=%esvjpassword% 

If service providers who advertise their service have created an account at 
eservicesvillage.com, they can edit the esv_user_name and esv_password fields in 
the configuration file above to the appropriate values. This allows them to login to 
eservicesvillage and manage/edit their services. 

Advertising a service within an enterprise 

Service providers can advertise the services within an enterprise in two ways. 

• Using a service directory (say LDAP) 

• Using only the e-speak core repository 

The first scenario is similar to using HP hosted global service directory except that 
the advertising service connects to the service directory specified by the service 
provider. This service directory can be located within the enterprise spread in 
different locations. Specifically, the advertising service is started by specifying (- 
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beproto <protocol>), (-behost <hostname>) and (-beport 
<portnumber>) command line options. If (-beproto) command line option is 
not specified, then global service directory hosted by HP is selected. 

In the second scenario, service providers who do not want to use service directory 
like LDAP can still achieve the same results by starting the advertising service in 
With repository mode*. When the user invokes the advertiseO call, the service is 
placed in the local advertising service. 

In this case, clients doing a search in a community, can specify fully qualified group 
names (group name+host name+port number). The infrastructure automatically 
connects and makes all the services available in the advertising service identified by 
host name and port number visible to the client, even when not using any service 
directory. 

Advertising a service in local domain 

Service providers advertising service in the local domain can do so in the following 
two ways. 

♦ Using a service directory (say LDAP) 

• Using only the e-speak core repository 
The first scenario is same as described above. 

In the second scenario, the users can use the spontaneous discovery mechanism in 
the e-speak system. Service provider's advertisements are automatically 
transferred to all the advertising services belonging to the same group. 

Clients doing a search in a community, need to specify only the group names. The 
hostname and portnumber are no longer necessary in the local domain, as the 
advertising services spontaneously talk with each other in the local domain and 
exchange information. 

Multiple groups in a single service directory 

Multiple groups can be in a single service directory (say LDAP). In this case, 
different advertising services belonging to different groups can connect to the same 
service directory and advertise services. 
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Selecting a group name 

Two different service providers can advertise services with exactly the same 
descriptions (attribute values). If the service provider wants to prevent collisions 
across the advertised services or wants to protect the access to the services 
advertised, the service provider can specify sufficiently unique group name for the 
advertising service. Specifically the service provider uses (-group 
<groupname>) command line option of advertising service to achieve this. It is the 
service provider's and client's responsibility to select a sufficiently unique name for 
the groups to prevent collisions. 

A client doing a search can specify a community which is a collection of group 
names. In this case, only services registered in the those groups are returned to the 
client. Services in other groups, even if matching client's query are not returned. 

A service provider wishing to advertise the service to the whole world can do so by 
starting the advertising service with group name ' speaktome * and using the HP 
hosted global service directory. Specifically, the service provider starts the 
advertising service with command line option (-group " speaktome ") 

Setting Current Community 

The following two Application Programming Interfaces (APIs) in the 
ESServiceContext class are used to create the community in which a search or 
a registration of a Service is to be performed. 

The getCurrentCommunity and set Community methods are as follows: 

public ESCommunity getCurrentCommunity () ; 
public void set Community (ESCommunity community); 

ESCommunity 

To add an entry to the list of groups, use the following code: 

public void add (String groupName) ; 
The default community is defined by the start-up file. 
To remove a group from the community, use the following code: 
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public void remove (String groupName) ; 
NOTE: Note: This is included in future releases. 
To return the enumeration of group servers, use the following method: 

public Enumeration 1 is tGroup Servers () ; 
Example: csldemoB . rgv . hp . com: 22 022 /group. 

Advertising to Groups 

As mentioned earlier, advertisement of Services is managed by 
ESServiceElement. An advertise call makes the Service visible to the entire 
group. To advertise a Service, use the following method: 

public void advertise (); 
If a Service needs to be advertised to a different set of groups, use the following 
method: 

public void advert iseToOtherGroups (String [] groupNames) 

where each element in groupNames is in the form 
<hostname> : port number /name. 

Finding in Communities 

All the user needs to do to find a Service in a community is to set the current 
community to the one of interest and invoke the finder method to find the Service. 

ESServiceContext connectContext = 

coreConnection . getServiceContext { ) ; 
connectContext . setCommunity (owncommunity) ; 

finder .find (query) ; 
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Security 

The most basic notion in security is the notion of identity that is determined by its 
key-pair. In order to invoke operations on a security-enabled service, a client 
requires an appropriate certificate. This certificate must be signed either by the 
service provider's principal himself or by another principal who is linked by a chain 
of delegation to a principal listed in the trust assumptions of the service provider. 
With security enabled in the core, service providers and service client require 
certificates to enable them access to core apis. For instance, to register a service 
and to perform find operations. The principal representing the core issues 
certificates to both client and provider enabling such access. 

When security is enabled, start up of any e-speak client (service client or service 
provider) reads two files: the trust assumptions and the certificates. Both these are 
actually just lists of certificates: the former being used by a service provider and the 
latter being used by a service client. In the base case, the service provider requires 
only one certificate: that for accessing the core. The service client, on the other 
hand, requires one for accessing the core and one or more for accessing the service 
itself. The client certificate list is merely a concatenation of these. An example of a 
certificate that the core can provide a service provider looks as follows, the binary 
data has been truncated for brevity. 

(signed (cert 

(issuer {public-key elgamal-pkcsl 
"\003\017v\245\235b\004\345\211\225\021 [\203=\256/ 

K\256\375\032\217:\351\024\327\304\342\312B\*\311\016\007\3 04 A \2 052\322\27 
l@\304 v <\370\204\036j\220\030\2217aD*\242\335|\233H\334N\201?.Uq\236) ") ) 

(subject (public-key "elgamal-pkcsl" 
"\003\017v\245\235b\004\345\211\225\021 [\203=\256/ 

K\256\375\032\217:\351\024\327\304\342\312B\'\311\016\007\3 04 A \2 052\322\31 
6r+")) 

(propagate) 

(tag (net. espeak. method (*) (*) (*))) 

(not-before 2000-05-25JL0 : 15 : 28) 

{not-after 3000-05-25_10 : 15 : 28) 

) (signature {hash SHA-1 
»\032\356V\317\260\t\347\331\277]\'\0278\237\0301t\212#\210") (public-key 
elgamal-pkcsl "\003\017v\245\235b\004\345\211\225\021 [\203=\256/ 
K\256\375\032\217:\351\024\327\304\342\312BV \311\016\007\3 04 A \2 052\2 01? .U 
q\23 6) ") 

,, \003\017^97\317^\377\ f \303\347yC\337+\221$Sm\202\242\201\214w\004\352&\31 
03U-/\272\\342\301\330\034") ) 
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A certificate that a service provider, a print service in this example, provides to a 
client that allows the client to invoke an operation, such as print, on it looks as 
follows (the binary data has been chopped) : 

{signed (cert 

(issuer (public-key elgamal-pkcsl 
"\003\017v\245\235b\004\345\211\225\021 [\203=\256/K\256\364p\255 | \335 " } ) 

(subject (public -key "elgamal-pkcsl" 
"\003\017v\245\235b\004\345\211\225\021 [\203=\256/ 
K\256\311\301\273\307l\323\316r+") ) 

(propagate) 

(tag (net . espeak. method PrinterServicelntf (* set print) (*))) 

(not -before 2000-05-25_10 : 15 : 28) 

(not-after 3000-05-25_10 : 15 :28) 

) (signature (hash SHA-1 
,l \0237\340}\ 1 \310I\263 8mq\207V\265\3 57\342\201\2702\274 " ) 
(public-key elgamal-pkcsl 

"\003\017v\245\235b\004\345\211\225\021[\203=\256/ 

K\246\374\032\020\244\004\004T\307\221\037\247\034\332\365\3648«\300\274\3 
62") ) 

When a message invoking an operation is received, J-ESI extracts the interface and 
method from it, and gets the service identifier from the information passed to the 
service handler by the core. From this it constructs the tag required to authorize the 
operation. The authorizer first checks to see if the tag is contained in the resource 
mask, and if it does, the operation is permitted. If the operation is not in the mask, 
J-ESI looks for a valid certificate (or certificates) that contain the tag needed to 
invoke the operation. The tag matching rules used for authorization are explained 
in the E-speak Architecture Specification chapter on "Access Control". The 
certificates checked by J-ESI are those presented by the client to establish the 
session 

J-ESI provides service providers with means to set metadata and resource masks 
that can mask access control to their services. See Appendix H for details on how 
to set up your security environments in e-speak. 

The default behavior when security is enabled is to require authorization for all 
operations. Service providers can create masks and associate them with service 
elements that they create. Masks enable Service providers to allow operations 
without any authorization. Any client is allowed to perform any operation that is 
specified in the mask for the service. If an operation is not included in a mask, only 
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clients that have been given certificates authorizing access are allowed to invoke 
the operation. The security infrastructure examines the certificates that have been 
presented by the client to see if they contain a tag authorizing the operation. The 
rules for how tags authorize operations are explained in the E-speak Architecture 
Specification "Access Control" chapter. 

Masks 

There are two types of masks: the metadata mask for metadata operations and the 
resource mask for resource specific operations. For example, service providers can 
control who can mutate the metadata of the service that they have created using the 
metadata masks, and they control who can invoke operations on services provided 
by them using the resource specific masks. 

Masks are specified as tags. The basic method tag format is 

(net .espeak. method <interface name> <method name>) 

The tag format is explained in detail in the E-speak Architecture Specification 
"Access Control" chapter. In the metadata mask, the interface name is the core 
interface being specified, and the method name is the operation in that interface. 
For metadata, the interface is likely to be ResourceManipulationlnterface, and the 
method name one of its methods. 

In the resource mask for a J-ESI service the interface name is the fully-qualified 
name of the interface class. The method name is the name of the method in the 
interface, plus the concatenated argument types. This allows overloaded methods 
to be distinguished. 

The metadata mask is used by the in-core metaresource when performing metadata 
operations. The resource mask is passed to the service handler by the core for the 
service handler to use when performing operations on the service itself. 

The masks are completely general tags, so the mask tag itself, or any of its fields, 
may use the tag matching features such as sets, prefixes and ranges. The interface 
and method names, for example, do not have to be string literals, they can be sets 
or prefixes. 

This tag masks method foo in interface net.espeak.examples.ExampleIntf: 

{net .espeak .method net . espeak . examples . Examplelntf foo) 



Developer Release X.03.03.00, September 2000 



115 



Security 



Extended Services 



This tag masks all methods beginning with foo: 

(net . espeak . method net . espeak . examples . Examplelnt f 
{* prefix foo) } 

This tag masks methods foo and bar: 

(net . espeak . method net . espeak . examples . Examplelnt f 
(* set foo bar) ) 

Methods with prefix foo or bar: 

(net . espeak . method net . espeak . examples . Examplelntf 
(* set {* prefix foo) (* prefix bar))) 

All methods in the interface: 

(net .espeak. method net .espeak. examples. Examplelntf ) 
This is equivalent to 

(net .espeak. method net .espeak. examples . Examplelntf (*) ) 
since missing trailing elements match anything. 
Methods foo in InterfaceA and bar in InterfaceB: 

{* set (net .espeak. method InterfaceA foo) 
{net .espeak. method InterfaceB bar)) 

All methods: 

(net . espeak . method) 
or simply 

(*) 

The full form of the method tag is actually: 

(net .espeak. method <interface name> <method name> <service>) 

In the normal case, the service handler is only interested in its own operations, so 
it does not care what the service field is. Since omitting a trailing field is equivalent 
to giving it the value (*), we omitted this detail above. 
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Authorizing Access 

General tags can be constructed using the following method in ESSecurityEnv: 
ADR createTag (String s) throws IOException 

The IOException subclass netespeak.security.adr.ADRParseException is thrown 
on a parse error. The parameter s is a string containing the input syntax for the tag. 

Method tags can be created using 

ADR createMethodTag (String interf aceName, 
String methodName, 
ADR service) 

Clients can retrieve their current security environment from the connection. For 
example: 

ESConnection conn= new ESConnect ion ( "config . file" ) ; 
ESSecurityEnv secEnv = conn.getSecurityEnvO ; 

For the purposes of resource masks, it is usual to use a tag containing simply (*) as 
the service parameter. In advanced applications, the service may want to set the 
service parameter to its service id, but this is not necessary. 

After a mask tag has been constructed, it is used in ESServiceElement methods: 

void setResourceMask (ADR tag) throws ESException 
void setMetadataMask (ADR tag) throws ESException 

Before a service is registered, these simply affect the local state. After registration, 
these set the local state and update the service metadata. 

Masking can be turned on or off using ESAuthorizer: 

void setMasking (Boolean x) 

When masking is off, the resource mask is ignored by the service authorizer even if 
set. Setting masking off in the authorizer has no effect on the resource metadata, or 
the in-core metaresource handling metadata operations. Masking can be turned off 
completely, in the core and handler, by setting a mask to null 
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An ESAuthorizer is associated with each ESServiceElement, and one can obtain the 
authorizer associated with an ESServiceElement using the getAuthorizerO call in 
ESServiceElement 

ESConnection has methods for controlling the default resource and metadata 
masks used when services are registered: 

void setDef aultResourceMask (ADR mask) 
ADR getDef aultResourceMask () 
void setDef aultMetadataMask (ADR mask) 
ADR getDef aultMetadataMask () 

void setMasks (ADR metadataMask, ADR resourceMask) 

After a default mask is set, all resources registered use it until it is changed. Unless 
the default masks are set explicitly, ESConnection uses null for them, causing 
authorization to be checked for all operations. 

Example 

In the example below, the service provider sets up a mask for the print method and 
a mask for the checkStatus method. Clients who present tags that match the print 
method are allowed to print and all clients are allowed to invoke the checkStatus 
method. The access control for the checkStatus method is disabled because of the 
setResourceMask method invocation in ESServiceElement. 

public static void main (String [] args) 
{ 

try { 

ESConnection conn = new ESConnection ("espeak.cfg" ) ; 
ESSecurityEnv sEnv = conn.getSecurityEnvf ) ; 

String m2 = " (net . espeak. method PrinterServicelntf checkStatus)"; 
ADR adr2 = sEnv.createTag (m2) ; 

ESServiceDescription sd = new ESServiceDescription {) ; 
sd.addAttribute (ES Constants .SERVICE_NAME, "printer") ; 
sd.addAttribute ( "Description" , "my hp printer"); 
ESServiceElement se = new ESServiceElement (conn, sd) ; 
se . setResourceMask (adr2 ) ; 

ESAuthorizer esa = (ESAuthorizer) se .get Authorizer ( ) ; 
esa. setMasking(true) ; 

se . set Implementation (new PrinterServicelmpl () ) ; 
se. register () ; 
se .advertise ( ) ; 
se .start { ) ; 
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} catch (Exception e) { 
e.printStackTraceO ; 

} 

} 

Clients who want to invoke this print service must obtain the tags to invoke this 
service and install them in their security environment. 

Remote Connection Manager 

Using advertising service, groups and communities is the preferred way of 
exchanging service metadata between various cores. However, sometimes more 
fine grained control is required where you want to make the service available to a 
specific core or engine. This can be done with the aid of remote connection 
manager and remote service manager. 

Remote connection manager has set of simple methods that allows the application 
programmer to connect to the specified core, to disconnect from a core and to get 
a list of all connections that the local core maintains with other cores. To do this, 
first obtain the remote connection manager object from ESConnection. 

ESConnection conn = new ESConnection ( "file .prop" ) ; 
ESRemoteConnectionManager connMgr = 
conn.getConnectionManager { ) ; 

To open a connection to a remote core, the client can invoke the openConnectionO 
method on the connection manager. Typically, the client specifies the address and 
port number on the remote machine on which the remote core is running. 

String url = w tcp: abc . foo . com: 12345" ; 
String id = connMgr . openConnect ion (url) ; 

Clients can close existing connections with remote cores by invoking the 
closeConnection method in the connection manager. For example: 

connMgr . closeConnection (id) ; 

where id is the string that represents the id of the connection that is returned by the 
openConnectionO call. To get a list of connections that are currently open with the 
connection manager, use the following call. 

String [] ids = connMgr .get Connect ions {) ; 
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Exporting Vocabularies 

Before a Service can be exported, the Vocabulary it will use must be exported. An 
example of this follows: 

package tests , java .net .espeak. jesi .remote ; 
import net . espeak. jesi .* ; 
import net . espeak . infra . cci . exception . * ; 
public class Export 

{ 

public static void main (String args[]) throws Exception 

{ 

ESCormection es = new ESConnection {"localhost 11 , 12345, "TCP" ) ; 
System. out. println{" Connected to the first core\n"); 
ESRemoteServiceManager servMgr = es .getRemoteServiceManager ( ) ; 
ESRemoteConnectionManager connMgr = es .getConnectionManager ( ) ; 

//Creating the vocabulary 

ESVocabularyDescription vocabDesc = new 
ESVocabularyDescriptionO ; 

//Setting the vocabulary name 

vocabDesc. addAttribute ("Name" , "ESR_002Vocab" ) ; 

//Adding vocabulary properties 

vocabDesc . addStr ingProper ty { " testCaselD " ) ; 

//Registering the vocabulary 

ESVocabularyElement vocabElem = new 
ESVocabularyElement (es, vocabDesc) ; 

ESVocabulary vocabRegister = vocabElem. register {) ; 
System. out .println ( "Vocab registered" } ; 

ESAccessor [] accList - new ESAccessor [1] ; 
accList[0] = ( (ESAccessorHandle) vocabRegister) .getAccessorO ; 
System. out .println ("Exporting resources : " + accList [0] ) ; 

// Connection to second core 

ESConnection connection = new 
ESConnection { " localhost , 12346 , "TCP" ) ; 

System. out .println { "Connected to the second core"); 

ESVocabularyFinder vocabFind = new 
ESVocabulary Finder (connection) ; 

try 

{ 

ESVocabulary vocabTemp = vocabFind. find ( new ESQuery{ 

"Name == 1 ESR_0 02 Vocab' " )); 
} catch (LookupFailedExcept ion look) { 
System. out .println ("Lookup before Export Failed");} 
//Export 

servMgr . exportService (accList, 

connMgr . openConnect ion ( " tcp : localhost : 12346" ) , 
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ESConstants . EX PORT_BY_ VALUE , 
true) ; 

//find vocab after Export 

ESVocabulary vocabl = vocabFind. f ind( new ESQuery( 

"Name « ' ESR_002Vocab ' " )); 
ESAccessor accessl = { (ESAccessorHandle) vocabl) .getAccessor { ) ; 
if {accessl==null) 

System. out .print In ( "Error" ) ; 

else 

System. out .print In ( "Lookup after Export Success"); 
System. out .print In ( n *********** SUCCESS DONE 
****************** ii j . 

} 

} 

Exporting Services 

Remote service manager is used to control transfer of service metadata from one 
core to another. This allows clients of one core to export their service descriptions 
to other cores on a selective basis. The remote service manager is obtained from the 
ESConnection by 

ESConnection conn - new ESConnection ( "file .prop" } ; 
ESRemoteServiceManager servMgr = 
conn.getRemoteServiceManager ( ) ; 

Now, suppose the service provider has registered a series of services with the e- 
speak core and has the accessors for the service in an array of ESAccessors called 
accessors. Furthermore, suppose that the id of the core to which the service 
provider has opened a connection is id. Additionally, the exporter has to specify 
whether the export should occur by value or by reference, and in the case of 
accessors corresponding to folders, the exporter has to determine whether the 
export should recursively export sub folders of the current folder, or should it 
export only the current folder. The invocation of the exportResource method looks 
as follows: 

servMgr. export Service (accessors, id, exportType, level); 
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The exportType is an integer that is 1 if the services are to be exported by value and 
2 if the services are to be exported by reference. In addition, set the boolean flag, 
level to false if the contents of a folder are to be recursively exported, and to true if 
only the top level of the folder is to be exported. A similar interface can be used to 
import resources. 

servMgr. import Service (accessor, id, importType, level); 

To unexport an exported resource from a remote core, the service can invoke: 

servMgr.unexport Service (accessor , id) ; 

To unimport an imported resource, the service provider can invoke: 
servMgr.unimportService (accessor, id) ; 



Events 

This section describes the design details of the Event Service, a lightweight, 
extensible Service targeted at loosely coupled, distributed applications. Events 
provide a publish-subscribe mechanism for communication built on top of e-speak 
messaging. 
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E-speak supports an extended form of the familiar publish-subscribe Event Model 
There are four logical entities in the e-speak Event Model whose interactions are 
shown in Figure 14. These entities are the Publisher, Listener, Distributor, and 
Subscriber. 



Figure 14 Interactions in the Event Model 

A Publisher (marked P in the figure) is an entity that generates an Event notification 
message. The recipient of an Event notification is called a Listener (L) . A Distributor 
(D) is an extension of a Listener. It receives Events and forwards them to other 
Listeners. A Subscriber (S) is an entity that registers interest in a particular Event 
with a Distributor and designates the Listener to whom Events are sent. The 
Subscriber and the Listener are typically the same physical entity. Similarly, it is 
fairly typical for a Publisher to act as a Distributor of its own Events. 

The Core itself is an example of an Event Publisher. It sends Events to a trusted 
Client called the Core Distributor to signal state changes such as a change in a 
Service s attributes. The Core Distributor can then distribute these Events to 
interested Clients that have appropriate authority. 
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Interaction Sequence 

Figure 15 shows a typical Event notification process where the Subscriber and 
Listener are folded into a single Client. 




L ' Core 

Figure 15 Typical Event notification process 

The following numbers in the figure represent these steps in the process: 

1 Distributor registers with the Core. 

2 Publisher discovers the Distributor, 

3 Publisher sends pub 1 i s h request to the Distributor describing the Events it will 
be generating, 

4 Subscriber discovers the Distributor. 

5 Subscriber sends subscribe request to a Distributor describing the Events in 
which it is interested. 

6 Publisher sends the Event to the Distributor using a not i f y message. 

7 Distributor forwards the Event to the Subscriber (also using a notify request) . 
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Subscribing to Events 

The Event APIs provide simple mechanism by which Clients can express interest in 
various Events and handle them. The following code shows how a printer Client 
subscribes to outofpaper and paperjam Events and handle them subsequently. 

String proper tyFileName = new String (* /users /connect ion. prop" ) ; 
ESConnection coreConnection = new ESConnect ion (property FileName) ; 



ESSubscriber print erEventSubscriber = 

new ESSubscriber (coreConnection) ; 
print erEventSubscriber . addEvent 

{ "hp , headof f ice . f irstf loor .printer . outofpaper" ) ; 
print erEventSubscriber .addEvent { 

{ "hp. headof f ice. f irstf loor .printer .paperjam" ) ; 
printerEventSubscriber . setlmplementation 

{new PrinterEventHandler { ) ) ; 
ResultSet rs = printerEventSubscriber . subscribe 0 ; 

public class Print EventHandler implements ESListnerlntf 

{ 



public String not if ySync (Event evt) 

{ 

System. out .println (evt .getPayload ( ) ) ; 
return "Notified" ; 

} 

public void notify {Event evt) 

{ 

System. out .println (evt .getPayload ( ) ) ; 

} 



The event subscriber, after connecting to the e-speak core, creates an instance of 
ESSubscriber and expresses interest in certain event using addEvent call. 
Furthermore, the subscriber sets the handler for the Events in which it is interested 
using setlmplementation ( ) . The handler should implement the 
ESListenerlntf . Then the subscriber invokes subscribe ( ) to register with 
the existing distributors in the community. The community is set using 
setCommunityQ call in ESServiceContext. The ResultSet obtained as a 



Developer Release X.03.03.00, September 2000 



125 



Events 



Extended Services 



result of subscribe 0 call contains success or failure of subscription with 
different distributors. The subscriber can subscribe to e-speak service events in a 
similar manner. The subscriber can also subscribe to e-speak core events using 
ESCoreSubscriber class. The list of e-speak service and core events are 
mentioned towards the end of this section. 

The following code gives a simple example of how to subscribe to service events, 
for e.g., service.create. This subscribes the user to any service creation events in the 
community. 

String proper tyPileName - new String ( w /users/connect ion. prop" } ; 
ESConnection coreConnection = new ESConnection (propertyPileName) ; 



ESSubscriber serviceCreateSubscriber = 

new ESSubscriber (coreConnection) ; 
serviceCreateSubscriber . addEvent 

( u service .create" ) ; 
serviceCreateSubscriber . set Implement at ion 

(new PrinterEventHandler ( ) ) ; 
ResultSet rs = serviceCreateSubscriber . subscribe () ; 

Publishing Events 

Publishing events is done using the ESPubli sher class. The usage is similar to that 
of subscribing to events. 

String propertyPileName = new String ('V users /connect ion .prop" ) ; 
ESConnection coreConnection = new ESConnection { proper tyFileName) ; 



ESPublisher printerEventPublisher = new 

ESPublisher (coreConnection) ,* 
printerEventPubl isher . addEvent 

( "hp.headof f ice. f irstf loor . printer .outof paper" ) ; 
printerEventPubl isher . addEvent ( 

( w hp .headof f ice . f irstf loor .printer .paper j am" ) ; 
printerEventPublisher .publish () ; 



Event outofpaperEvent = 

new Event ( w hp .headof f ice. f irstf loor. print er.outof paper" ) ; 
outofpaperEvent . setPayload{ n printer foo out of A4 paper"); 
printerEventPublisher. s endNot if y (outofpaperEvent) ; 
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Just as the subscriber expresses interest in receiving events, the publisher 
expresses interest in sending events. The publisher does this by instantiating the 
ESPublisher class, adding events of interest using addEvent and then calling 
publish ( ) . publishO does not send an event to the consumer, rather it just 
expresses intent to publish those events at a later point of time. Actual publishing 
of events takes place when the publisher calls sendNotif y ( ) after constructing 
an Event object. There is a default publisher available with the ESConnection 
that can be obtained using the getDef aultPublisherO call. This is used for 
publishing only the e-speak service events. The list of service events is given at the 
end of this section. 

Distributing Events 

So far we have talked about a simple subscriber and publisher assuming that there 
is already a distributor is available for the outofpaper and paperjam events. In case 
no such distributor is available, the publisher of the events can write a simple Event 
distributor as follows. 

String propertyFileName = new String ( "/users/connection. prop" ) ; 
ESConnection coreConnection = new ESConnection (propertyFileName) ; 

ESDistributor printerEventDistributor = new 

ESDistributor (coreConnection) ; 
printerEventDistributor . addEvent 

( "hp . headof f ice . f irstf loor . printer . outofpaper" ) ; 
printerEventDistributor . addEvent { 

( tt hp . headof f ice . f irstf loor . printer .paper j am" ) ; 
printerEventDistributor. start () ; 



printerEventDistributor . shutdown ( ) ; 

The distributor creates an instance of ESDistributor and adds events which the 
distributor intends to distribute using the addEvent ( ) call. The distributor then 
starts using the start ( ) call. The distributor can be stopped using shutdownO 
call There are some pre-existing Event distributors bundled with the e-speak core. 
These are started along with the e-speak core. They are the service distributor and 
the core distributor. These distribute the service and core events listed at the end of 



Developer Release X.03.03.00, September 2000 



127 



Events 



Extended Services 



this section. It is possible to subscribe to core events distributed by the 
ESCoreDistributor. It is possible also to subscribe and to publish service 
events that are distributed by the ESServiceDistributor. 



List of Service Events 

This section lists the Service Events generated by e~speak. 

service . create This Event is generated by e-speak Service interface 
when a Service is created. 

service .mutate This Event is generated when a Service's attributes 
are mutated. 

service . delete This Event is generated on deletion of a Service in 
the e-speak Service interface. 

service . access This Event is generated whenever the ESAccessor 
of a Service is used. 

service .pause A Service can voluntarily generate this Event for 

temporary pause of its Services. 

service . resume A Service can voluntarily generate this Event on 
resumption of its Services. 

service . gener icinf A Service sends out generic information about itself 
° through this Event type. 



List of Core-Generated Events 

This section lists the Events generated by the e-speak Core. 

core .mutate .NameFrame Inter face . 3 Bind a Resource to a new name in an 

existing Name Frame. 

core .mutate . NameFrameinterf ace . 4 Rebind an existing name in a Name 

Frame to a new Resource, 
core. mutate. NameFrameinterf ace. 5 Unbind a name from a Resource. 
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core .mutate .NameFramelnterf ace . 6 

core .mutate .NameFrame Inter face . 7 

core .mutate . NameFrame Inter face . 8 

core .mutate . Vocabularylnterf ace . 3 

core .mutate . ResourceFactory Inter face . 1 

core .mutate . ImporterExporterlnterf ace . 1 

core .mutate . ImporterExporterlnterf ace . 5 

core. mutate. ResourceManipulationlnter face. 
1 

core .mutate . ResourceManipulationlnter face . 
3 

core .mutate . ResourceManipulationlnterf ace . 
5 

core .mutate .ResourceManipulationlnterf ace . 
9 

core. mutate. ResourceManipulationlnter face . 
11 

core .mutate . ResourceManipulationlnterf ace . 
13 

core .mutate . ResourceManipulationlnterf ace . 
23 

core . failure . invalid_parameter 
core . failure . null jparameter 
core . failure . invalid_value 
core . failure . invalid_type 
core . failure . out_of _order 
core . failure . Core_panic 



Copy a binding from one Name Frame 
to another. 

Add a binding to a Resource to an 
existing name. 

Remove a binding to a Resource from 
an existing name. 

Modify the attribute set of a 
Vocabulary. 

Register a new Resource. 
Import a new Resource. 
Update an imported Resource. 
Unregister a Resource. 

Modify the owner of a Resource. 

Modify the handler of a Resource. 

Modify a public RSD of the Resource. 

Modify a private RSD of the Resource. 

Modify the attributes of the Resource. 

Modify the export-type of the 
Resource. 

Pass an invalid parameter. 
Pass a null parameter. 
Receive an invalid value. 
Receive an invalid type. 
Out of order. 

Core has an irretrievable exception. 
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core . 


failure 


. service_panic 


Service has a critical exception. 


core. 


failure 


. recoverable_Core 


Received exception recoverable. 


core. 


failure 


. repository_f ull 


Repository is overflowing. 


core. 


failure 


. partialis tatus_update 


Status update is partial. 


core. 


failure 


• request_not_delivered 


Request not delivered. 


core . 


failure 


Dermission denied 


Pprmi^inn HpnipH fnr tbi^ rvnprafinr 

1 wl 11.11001 Oil UCllltU Xvl UXitJ UL/Ci QUUi 


core . 


failure 


. tinde liver able request 


Rpnup^t nnt rlplivprablp 


core . 


failure 


.unrecoverable delivery 


Unrecoverable delivery exceotion 


core . 


failure 


.recoverable delivery 


RprnvpraHlp HpIivpfv pyrpntinn 


core. 


failure 


.quota exhausted 


Resource Quota exhausted 


core • 


failure 


nam i no 


Ma mi no PYPpnfinn T&rpiv&H 

IMClliiXilg CALCUUUXL 


core . 


failure 


pnrn tv mane ino 


\/fannin<7 pmntv pvppnfinn 

iYiCIL/ IJJ.1 Xti ClXljJLy CALC VJ HW1X. 


core . 


failure 


.unresolved binding 


Pvrpntinn in binding rp<5 oil it ion 
occurred. 


core. 


failure 


.multiple_resolved_binding 


Multiple resolved binding failures 
occurred. 


core. 


failure 


. name_no t_f ound 


Name does not exist. 


core. 


, failure 


. stale_entry_access 


Stale repository entry accessed. 


core. 


failure 


,name_collision 


Name collision exception occurred. 


core. 


failure 


. lookup_f ailed 


Lookup attempt failed. 


core. 


failure 


. service_f ailed 


Service failed. 


core. 


failure 


.nameframe_f ailed 


Name Frame failed. 


core. 


failure 


. invocation^ ailed 


Invocation failure occurred. 


core . 


failure 


. invalid_name 


Invalid name detected. 


core. 


failure 


• remote 


Remote failure occurred. 


core. 


failure 


. exporter 


Exporter failed. 


core. 


failure 


•exception 


All other exceptions. 
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There are two aspects to threading when programming with J-SEI. 

• The threads that the service handler uses to handle requests to the service 

• The threads in the client program that may share a connection to the core. 

When service providers create services, they create service handlers. These service 
handlers can be set up so that there are many threads that handle requests to this 
service. Essentially, each service handler comes with a ESThreadPoolManager that 
manages the pool of threads for servicing requests to this service. Furthermore, 
there are two main policies that can be used by the service provider: 

• Thread per request: When the configuration indicates that the service provider 
wants to spawn off a thread per request, the ESThreadPoolManager creates a 
new thread to handle every request for the service. This thread runs to 
completion at the end of the request. 

• Fixed thread pool: In this case, the thread pool manager has a fixed pool of 
threads that depends on the number of threads that the client has indicated in 
the ESServiceHandler. The client can set the number of threads she wants by 
using the setNumThreads(int num) in the ESServiceHandler. 
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Client applications in can be multithreaded. A Client can choose to create a 
connection to the Core and then create multiple threads (using the native Java 
threads) that use this connection simultaneously. 




TiftpStrriii 

Figure 16 An example of threads 

Because these threads share the same connection, any state stored in 
ESConnection is shared across all these threads. In certain situations, this is 
undesirable when the threads need to operate independently of each other. 
ESThread is used in these situations. 

An example of where this problem can occur is the use of the 
setCurrent Folder ( . . ) API t to set the current folder in which new bindings are 
created. If multiple threads need to change the working directory without affecting 
other threads, then these threads should be created using an ESThread ( ) call, 
which clones the ESConnection state on creation of the thread. 

Just like Java Threads, there are two ways of using the J-ESI threads. 

* Application developer creates a Java file which implements ESRunnable 
(counterpart of Java Runnable) and passes this to the constructor of 
ESThread (counterpart of Java Thread). The application developer does this 
if his Java file already extends some other Java class and hence could not extend 
ESThread directly. This is the suggested and preferred way of using ESThreads. 
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ESThread threadl « new ESThread (esrunnable) ; 
threadl . start ( ) ; 

Application developers can also extend ESThread directly. An example is as 
shown below. 

public ApplThread extends ESThread 

{ 

public ApplThread (ESConnect ion coreConnection) 

{ 

super (coreConnection) ; 

} 

public void run() 

{ 

ESConnect ion clonedConnection = 
super .ge tConnect ion {} ; 



clonedConnection. get Service Context {) . 
setCurrentFolder {...); 



} 

} 

For example, the following code fragment creates two threads that operate on the 
same connection: 

public class ThreadTest 

{ 

public static void main (String args [] } 

throws ESInvocationException, ESLibException, 
InterruptedException, IOException 

{ 

String propertyFileName = new String (" /users /connect ion. prop" ) ; 
ESConnection coreConnection = new ESConnection (propertyFileName) ; 
ApplThread threadl = new ApplThread (coreConnection) ; 
ApplThread thread2 = new ApplThread (coreConnection) ; 
threadl . start ( ) ; 
thread2 . start { ) ; 

} 

} 
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E-speak Clients discover Services and interoperate with them using a remote object 
model or using Events. In addition to these approaches, e-speak supports a purely 
messaging interaction model with the ESServiceMessenger class. 

Clients send and receive messages using synchronous or asynchronous messages 
to other Services represented by the ESAccessor associated with the Service. 

ESServiceMessenger messenger - 
new ESServiceMessenger (core Connect ion) ; 

The messenger can be used to send a payload object synchronously or 
asynchronously to any other Service. To send an object, use the following code: 

Object payload - new Object () ; 

ESService myService = f inder . find (query) ; 

ESAccessor serviceAccessor = ( (ESAccessorHandle) myService) . 

getAccessor () ; 
Object retValue - messenger . sendSynchronous 

(serviceAccessor, (Object) payload) ; 

or (to send asynchronously): 

ESMessage msg = messenger . sendASynchronous 
(serviceAccessor, (Object) payload) ; 

When an asynchronous message is sent, a message ID is returned in the form of an 
ESMessage. The service sending an asynchronous message may expect a 
notification to be returned. It can wait for a reply using the wait method as follows: 

messenger .wait (msg) ; 

where msg is the return value of the asynchronous send. 
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A Service expecting to receive messages can instruct the ESServiceMessenger 
to receive messages destined for a particular service element by using the following 
code: 

ESMessage msg = messenger . receive (se) ; 
where se is an ESServiceElement which has been initialized and registered. 

On receipt of a message, a Service can extract its payload, operate on it. To extract 
the payload from the ESMessage, use the following method: 

Object obj - msg. get Pay load () / 

On operating on the payload, the service can reply to a message by invoking the 
reply 0 method on it. 

Object repObject = new Object (}; 
msg. reply (repObject) ; 
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The purpose of ESIDL compiler is to prepare the code that enables programmer of 
client code to invoke services as if they were running in the same process space. 
Such code includes stub, registering into message registry and serialization of 
objects. 

ESIDL compiler can create new code and check existing code for conformance. 
Both e-speak serialization and Java serialization are supported. 



Generating code 

ESIDL compiler uses as input description of services, types, and exceptions and 
creates support files needed by user to invoke service through e-speak. 

There are two kinds of description: 

• services are described in service description files 

• types and exceptions are described in type description files. 
There are several kinds of support files: 

• interface files that define service interfaces 

• stub files that represent service on client side 

• message registry files that are used to register classes with e-speak messaging 
layer 

• class files that implement data types and exceptions 
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Data type description can be in an ESIDL file (extension ".esidH or in a Java file 
(extension "Java ). Service description can be only in an ESIDL file. ESIDL files are 
checked and new code is generated from them. If files of both types exist, then the 
ESIDL file is used as input. 

Processing Java files is new to ESIDL compiler. 



Input Files 

Service Description 

Service description includes information about an e-speak service. For ESIDL 
compiler every parameter it receives on the command line denotes an e-speak 
service. This is a change from the previous version where all service files and data 
types had to be listed. Interface file, stub file, and message registry file are 
generated for every e-speak service. 

Service. esidl & Servicelntf . java, ServiceStub. java, 
ServiceMessageRegistry . java 

Type Description 

Type description includes information about: 

* types of service attributes 

• types returned by service methods 

♦ parameters to service methods 

• exceptions thrown by service methods 

Type description files are not listed as command line parameters to the compiler. 
They are searched for using import statements in the same manner as javac 
compiler searches for the source files (CLASSPATH environment variable or 
-classpath option). 
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Type.esidl -> generated Type.java 
Type.java — > checked Type.java 



Output 



Files 



Interface 



File 



Interface file includes interface that the service implements. The interface extends 
ESService. 



Stub file includes code for: 

• serialization of service stub object 

• rerouting of service method invocations through core 

• calling messaging registry initialization (in message registry file) for return 
types, parameter types and exception types used in the service 



Message registry file includes code for registering types (for a list, see Type 
Description chapter) with MessageRegistry. 



Type file is generated from type description. Serialization code is generated (for 
.esidl files) or checked (for .Java files). E-speak serialization is default if none is 
specified (in declaration of type). Otherwise the specified serialization is used. 



Stub File 



Message Registry File 



Type File 



Developer Release X.03.03.00, September 2000 



139 



Command Line Parameters 



IDL Compiler 



Command Line Parameters 

Do not list all data type and exception files as the compiler parameters as it was 
required by the previous version of the compiler. 

Java net . espeak.util .esidl . IDIiCompiler [-classpathj cp <path-to- 
sources>] [-verbose] <service-desc> [<service-desc> ...] 

where: 

Semicolon separated list of directories where compiler 
searches for description files. V (dot) is used for current 
directory. If classpath is not specified, environment 
variable CLASSPATH is used. 

Instructs the compiler to print out information about 
created files. 



<path-to- 
sources> 



-verbose 



IDL Requirements 

Requirements have changed from the previous version and are now much less 
strict. 

Description in ESIDL file 

Service description is admissible if: 

• it is declared pub lie AND 

• all methods it declares are admissible 

A user-defined abstract class or a user-defined exception is admissible if: 

* it is declared pub lie AND 

* its parent type is either j ava . lang . Ob j ect or another admissible user- 
defined data type 

A service method is admissible if: 
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• return type and parameter types are admissible 

• exceptions thrown are admissible 

Description in Java file 

A user-defined data type (a Java class) must conform to these additional 
restrictions: 

• implements ESSerializableorj a va .io.Serializable interface 

A user-defined exception (a Java class) must conform to these additional 
restrictions 

• it must extend ESServiceException 

A service method is admissible if it throws ESInvocationException 
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J-ESI provides simple mechanisms for service providers and clients to monitor 
accesses to their services. Service providers can use these mechanisms to either 
generate management events such as billing events, create an access log, or provide 
mechanisms for performing load balancing, redirecting requests should a particular 
server be unavailable, etc. Clients can use interceptors for adding or removing 
parameters from requests or even implement a secure invocation interceptor that 
finds an available service with the required method and invoke it. 

In essence, each ESServiceElement object contains an ESIceptorControl object 
that controls the list of interceptors associated with the service element. The 
interceptor objects are instances of classes that extend the abstract ESIceptor 
class. The ESIceptorControl object therefore provides methods provides methods 
to add and remove interceptors from the ESServiceElement. When a message 
arrives for the service represented by the ESServiceElement, the message is passed 
through each interceptor that the service provider has associated with the 
ESServiceElement. 

Interceptors are classified based on whether they are terminal or not. A terminal 
interceptor is an instance of ESTerminallceptor, and represents an actual 
invocation to the service. There is a single terminal Therefore, the ESIceptorControl 
that is associated with any ESServiceElement, comes with a default 
ESTerminallceptor. However, the service provider can change that terminal 
interceptor with any other terminal interceptor that she writes. 

The service provider must go through the following steps in order to set up an 
interceptor; 

• Define an interceptor class that extends ESIceptor or ESTerminallceptor. The 
service provider must implement the invoke { ESReques t req) method in the 
extended class. Furthermore, if the interceptor being defined is an extension of 
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ESIceptor, she has to make a invokeNext ( ) call in the implementation of the 
invoke method. If this is not done, the interceptors that are added after this 
interceptor are not invoked. 

• The service provider also must implement the initialize (Obj ect 
params ) method in the interceptor class. This method is invoked when the 
interceptor is added to the Esiceptorcontroi and can be used to initialize the 
state of the interceptor. 

• When the service provider creates a ESServiceElement that represents the 
service, she makes an addlceptor (ESIceptor icp, Object params) 
that adds the interceptor to the interceptor control object associated with the 
service element. 

The service provider is free to override other methods in Eslceptor, but the invoke, 
and initialize methods must be implemented. 

We now present a simple example that shows using the interceptors. Consider the 
print service example from the previous sections. Suppose the service provider 
wants to: 

• balance the load among multiple print service implementations 

• generate information about each access to the print service 

This is accomplished by the following interceptors: the LoadBalancinglnterceptor, 
and the Printinglnterceptor 

public class LoadBalancinglnterceptor extends ESIceptor { 
// Array of backup services 
private ESService[] services; 
private ESService thisService; 

//If the service reaches this load backup services are invoked 
private int LIMIT_LOAD = 5; 
private String PRINT = "prints- 
public boolean invoke (ESReguest req) { 

System. out. print In ("LoadBalancinglnterceptor enter invoke"); 
if (req.getMethodName ( ) .equals {PRINT) ) { 
try{ 

ESRequest request = new ESRequest { ) ; 
// check services load 

int load = ( {PrintServicelntf ) thisService) .getLoadO ; 
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if (load > LIMIT_LOAD) { 

// the load is above limit load, invoke backup service 
int minLoadService = getLowestLoadService () ; 
PrintServicelntf ps = {PrintServicelntf } services [minLoadService] ; 
req. setRe turn Value {ps. print { (String) req. get Par am Value ( "argO") ) ) ; 
invokeNext (req) ; 

}else{ 

invokeNext (req) ; 

} 

} catch {Exception e) { 
return false; 

} 

}else{ 
try{ 

invokeNext (req) ; 
} catch {Exception e) { 

} 

} 

return true; 

} 



public void initialize (Obj ect param) { 

// implementation that initializes the services array, etc. 
/ / from information in param 

} 

private int getLowestLoadService {) { 
//... implementation 




//This is how the interceptor code looks like 

public class Print inglnterceptor extends ESIceptor { 
int cnt=0; 

public boolean invoke (ESRequest req) throws ESInvocationException{ 
if {req.getMethodName ( ) . toString{) . equals { "print" ) ) { 
cnt++ ; 

writeCountToLogFile ( ) ; 

} 

try{ 

invokeNext {req) ; 
}catch {Exception e) { 

} 
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return true; 

} 

private void writeCountToLogf ile ( ) { 
// implementation 

} 

public void initialize (Object param) { 

} 

Now that we have defined the two interceptors, the print server, looks as 
follows : 

public class PrintServer 
{ 

public static void main (String [] args) 
try { 

String propertyFileName = new String {"/users/connection. prop") ; 
ESConnection coreConnection = new ES Connect ion (propertyFileName) ; 
ESServiceDescription printDescription = 
new EServiceDescriptionO ; 

printDescript ion. addAt tribute ( "Name" , "printer" ) ; 
ESServiceElement printElement = 

new ESServiceElement (coreConnection, printDescription); 
printElement . set Implementation (new PrinterServicelmpl ( ) ) ; 
printElement . register ( ) ; 

printElement. addlceptor (new Printinglnterceptor () , "HP Lobby 49 U 
printer" ) ; 

LBIParams IbiParams = ..// initialize object expected by 
//initialize method of LoadBalancinglnterceptor 
printElement . addlceptor (new LoadBalancinglnterceptor ( ) , 

IbiParams) ; 
printElement. start {) ; 

System. out .println ("Started printer Service «) ; 



} 

} 



catch {Exception e){ 
// handle the exception 



In the above example, the printing interceptor is invoked before the loadbalancing 
interceptor on any request. If the service provider wants the order to be reversed, 
reverse the order of adding the interceptors to the service element. 
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The Account Manager allows administrators to create and manage accounts in e- 
speak. This means that administrators can create accounts, grant or change 
permissions for accounts, and occasionally delete accounts. In the current release, 
the Account Manager cannot grant, change or revoke account permissions, but this 
will be added in a future release. 



Programming Model 

The Account Manager module provides three basic abstractions, the Account 
Manager, the Account Profile, and the Account Description. The Account Manager 
allows basic account management functions, including creating and deleting 
accounts, authenticating users, and retrieving lists of accounts. Each account 
created by the account manager has an account profile associated with it, which is 
required for authentication of the account. To change the description associated 
with the account profile, a profile description with a valid (non-null) vocabulary 
must be supplied, together with the attributes to be added to the description. 

Profile Description 

The Profile Description describes attributes of the Account Manager. Since the 
default Account Manager vocabulary does not define a set of attributes that are 
expected, the user must provide a vocabulary that describes the attributes which 
will be included in this profile description, so that it can be added to the existing 
description of the account profile. In the account manager module, this abstraction 
is represented by the ESProf ileDescription class. 
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Account Profile 

The Account Profile contains the authentication information for the account. It is 
initialized with just the account name and password phrase and can be modified by 
adding a Profile Description to it. In the account manager module, this abstraction 
is represented by the ESAccountProf ile class. 

Account Manager 

The Account Manager allows the service administrator to perform administrative 
tasks such as creating and deleting accounts, retrieving lists of all accounts, and 
adding descriptions to existing accounts. The service administrator s main 
interaction to the Account Manager module is through the Account Manager 
abstraction itself. In the account manager module, this abstraction is represented 
by the ESAccountManager class. 

In this release, there are two default accounts defined in e-speak s core Account 
Manager: the admin account, and the guest account. The username, passphrase pair 
for the admin account is "admin, admin", and the corresponding pair for the guest 
account is "guest, guest". 



A Simple Example 

Consider an example where a service administrator decides to create an account 
temporarily, change its description, and then delete the account. At present, only an 
administrator or someone presenting the credentials of the account itself can delete 
an account. In a future release, there will be functionality allowing the granting of 
permissions to new accounts, and it is probable that some new accounts will be 
granted permissions to delete at least some subset of the existing accounts. 

First, to create the account, the service administrator should open a connection to 
an e-speak core. (The core is already running). After a connection has been 
established, its getAccountManager ( ) method can be used to retrieve the active 
ESAccountManager. The ESAccountManager can now be used by the 
administrator to perform normal account maintenance activities. 
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String propertyFileName = new String ( "/users/connect ion. prop" ) ; 
ESConnection esconn - new ESConnection (propertyFileName) ; 
ESAccountManager acctMgr = esconn .getAccountManager ( ) ; 

Now that we have retrieved the ESAccountManager, the administrator can create 
an account based on an account name. First, an ESAccountProf ile must be 
created using that account name. The newly created ESAccountProf ile is 
passed in as the associated profile for the account to be created. 

ESAccountProf ile acctProf = new ESAccountProf ile ( "test Account ") ; 
String acct = acctMgr . createAccount (acctProf } ; 

The account just created can be referred to by the java . lang - String returned 
from the creation. The administrator can now add a description to the account. To 
do this, he/she must first ensure that there is a valid vocabulary associated with it, 
then must create an ESProf ileDescription and add attributes to it that 
describe this ESAccountProf ile. 

ESVocabularyDe script ion vocDesc - new 
ESVocabularyDescription { } ; 

vocDesc. addAttribute(ESConstants.SERVICEJtfAME, M testVocab" ) ; 
vocDesc .addStringProperty ( "manufacturer" ) ; 
vocDesc. addStringProperty( "model" ) ; 
vocDesc .addStringProperty ( "year 11 ) ; 

ESVocabularyElement vc = new ESVocabularyElement (esconn, 

vocDesc ) ; 

ESProf ileDescription desc = null; 
ESAttribute [] atts = null; 
ESVocabulary vocab = null; 

try { 

vocab = vc. register () ; 
} catch (NameCollisionException nee) { 

nee .printStackTrace ( ) ; 
} catch (ESLibException esle) { 

esle .printStackTrace ( ) ; 
} catch (ESInvocationException esie) { 

esie .printStackTrace ( ) ; 

} 

desc = new ESProf ileDescription (vocab) ; 
desc.addAttribute ( "manufacturer", "Honda") ; 
desc. addAt t r ibut e ( "model" , "Civic") ; 
desc. addAttribute ("year" , "2 000") ; 
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try{ 

acctMgr . addDescription (acctProf , acct, desc) ; 
} catch (ESInvocationException esie) { 
esie.printStackTrace () ; 

} 

Now that there is an active account, with an account description, the properties just 
described in the ESProf ileDescript ion can be used to find this account again. 
To do this, an ESQuery is constructed, describing the value desired for the attribute 
in question, and this query is used as the argument to a find ( ) operation in an 
ESServiceFinder. This retrieves the list of services (accounts, in this case) that 
satisfy the requirements of the ESQuery, and then the service administrator can 
switch to this account using the switchAccount ( ) method of the active 
ESConnection. 

ESServiceFinder finder = new ESServiceFinder (esconn) ; 
try { 

ESQuery query = 

new ESQuery {vocab, 

" (manufacturer 'Honda') or (year ^OOO 1 )"); 
ESService[] serviceList - f inder . find (query) ; 

ESAccessor accessor = ( (ESAccessorHandle) 
serviceList [i] ) . 

getAccessor () ; 

esconn. switchAccount (accessor) ; 

esconn. init () ; 
} catch (LookupFailedException Ife) { 

lfe.printStackTraceO ; 
} catch (ESInvocationException esie) { 

esie .printStackTrace () ; 

} 

NOTE: The core finder assumes that a single char in single quotes is of type char and 
multiple characters in single quotes are of type String. If use a single char constraint 
for an attribute of type String the single char should be enclosed in double quotes 
and them it is interpreted by the core as string type. 
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The service administrator can also change to the account simply by creating a 
property file that describes the attribute and its value, and using that property file 
to create a new ESConnection. The following code snippet shows this method of 
changing to an account that has had an ESProf ileDescription added to it. 

Properties prop = new Properties (System. get Proper ties) ; 
prop. put ( "manufacturer" , "Honda" ) ; 
try { 

String propertyFileName = new String ( "/users/ 
connect ion. prop") ; 

ESConnection testConn = new ESConnection (propertyFileName) ; 
} catch (ESInvocationException esie) { 

esie .printStackTrace ( ) ; 
} catch (ESLibException esie) { 

esie .printStackTrace ( ) ; 

} 

Multiple queries can be included in the property file, one on each line, to create a 
complex constraint for the desired account. 

If there is a need to retrieve the ESAccountProf ile of an account, for example, 
when an account has been retrieved using one of the methods described above, the 
getAccountProf ile ( ) method of the ESAccountManager can be used. 

try { 

ESAccountProf ile retProf = acctMgr .getAccountProf ile ( 

acctProf, acct) ; 
} catch (ESInvocationException esie) { 
esie .printStackTrace ( ) ; 

} 

A valid ESAccountProf ile is required before an ESAccount Prof ile can be 
retrieved. This is to prevent unauthorized access to the profiles of accounts in e- 
speak. There are currently two valid ESAccountProf iles, the profile of the 
'admin" account, and that of the account itself. No other account profiles are 
authenticated to retrieve a third account profile. 

The administrator can also set the ESAccountProf ile for a given account, to 
allow, for example, changing of the password for the account. As in the previous 
example, a valid account profile is required in order to call the 
setAccountProf ile ( ) method on an account. 

ESAccountProf ile newProf = new ESAccountProf ile {name, newPwd) ; 
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try { 

ESAccountProf ile retProf = acctMgr . set Ac count Prof ile ( 

acctProf , newProf ) ; 
} catch (ESInvocationException esie} { 
esie .printStackTrace { ) ; 

} 

The getAHAccounts ( ) method can be used to retrieve a list of all the existing 
accounts. This list can, for example, be useful for checking whether a particular 
account name is already used. This method can be called with no authentication 
required for the caller. 

try { 

String [] accounts = acctMgr .getAllAccounts () ; 
} catch (ESInvocationException esie) { 
esie. printStackTrace {) ; 

} 

Finally, to delete an account, the caller must again provide a valid 
ESAccountProf ile, as well as the name of the account to be deleted. The 
account is only deleted if the provided ESAccountProf ile can be successfully 
authenticated. 

try { 

acctMgr .deleteAccount (acctProf, acct) ; 
} catch (ESInvocationException esie) { 
esie .printStackTrace { ) ; 

} 
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Introduction 

This document describes the current basic setup for using e-speak securely. 
Security is subtle and it is dangerous to treat it as just another thing to "select the 
check box*. 

This is the first release of e-speak with security and inevitably there are many 
practical issues relating to how e-speak enabled services and clients make effective 
use of security. These deployment issues will be discussed and decisions taken over 
the coming months. Hence, this initial release of secure e-speak is mostly 
concerned with basic deployment of the security architecture itself. After the 
architecture is deployed, the security is ready to be activated to enforce particular 
security properties as necessary. 

There are three main sections to this appendix. The first deals with the basic 
aspects of the security model, and in particular PSE s and certificates. The second 
section then discusses a bootstrap process used for testing purposes. The third and 
final section discusses security configuration files. 

The Basic Security Model 

A thumbnail sketch of the security model goes as follows: 

Everyone (and everything) has a set of public/private keys. Entities are distributed 
and interact with one another by means of secure sessions using the SLS protocol — 
this includes firewall traversal technology. All entities can both use services offered 
by others and also provide services to others. This means that all parties in secure 
sessions have to be authenticated to each other. In particular, SLS secure sessions 
authenticate both parties involved by using challenge-response negotiations based 
on public-key cryptography. 
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Access control to services is done by exchanging digitally signed certificates as a 
part of the SLS protocol providing secure sessions. These certificates act like 
"tickets* that grant entities with authorization to access and make use of services. 
Certificates are signed by issuing entities (or Principals) and are issued to subject 
principals who may use them. These certificates can also be chained together (using 
delegation) to give composite authorizations. 

Refer to the E-speak Architecture Specification chapter on * Access Control" for 
further details concerning the security model 

PSE's and Certificates 

A Private Secure Environment (PSE) represents a keystore containing public/ 
private key pairs. Each principal e-speak entity needs to have their own set of keys 
and thus needs to store them securely within a PSE. The PSE itself can be stored as 
a binary file in your local file system. This data is encrypted and a passphrase is 
required to lock/unlock the data it contains. 

The PSE is responsible for generating it's own key pairs — in particular, it has been 
designed so that private keys should never be exposed 1 . 

The other main function of a PSE involves validating and signing certificates. 
Validating a certificate involves checking the signature of the certificate using the 
issuers public-key (embedded within the certificate). Signing a certificate involves 
using a private key held within a PSE to create a digital signature, based upon a 
message digest of the certificate data. 

PSE Manager 

The PSE Manager is a GUI tool that supports these basic tasks: 

1 Creating a new PSE and saving it as a binary file. 

This involves selecting a passphrase that is used as an encryption/decryption 
key. It is important to keep this passphrase information secure— anyone 
capturing your PSE can perfectlymasquerade as you and access everything that 

von ran arrp<;<; Afco losing or forpptHno vnnr na^nhra<;p mpam that vou arp 

1 There is currently a method that can expose private keys - but this is only temporarily present 
to accommodate a deprecated internal interface that soon it is unnecessary to support. 
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unable to unlock or access your own PSE. For automatic operation, the PSE 
passphrase can be kept in a pass file stored on a floppy disk etc. There is a 
configuration option for this. 

2 Creating new keys-pairs. 

The PSE Manager can create new key-pairs, each of which are given a symbol 
label. These labels can then be used when constructing certificates. Note that 
this labels are referred to as roles in espeakxfg and some of the security code. 

3 Creating and editing certificates. 

Attribute certificates typically contain information about the issuer, the subject, 
what is being authorized and the validity period. For convenience, the PSE's 
symbolic labels (or roles) for keys can be used to refer to known keys when 
constructing certificates— thus avoiding tedious and error-prone data entry of 
key information. 

4 Validating and signing certificates as described above. 

PSE data can be saved to binary files (using a passphrase for the encryption key) 
and certificates can be saved to text files etc. 

For further information on the PSE Manager, refer to the PSE Manager user 
documentation. 



Bootstrap process for testing 

The bootstrap process for testing purposesxs as below. When writing and deploying 
secure applications, refer to the J-ESI documentation and the E-speak Architecture 
Specification. 

1 Use the PSE Manager GUI tool to do the following: 

a Generate a keystore object (i.e. a Private Secure Environment) and is typi- 
cally called securestore . txt. This is presently shared by all partici- 
pants — the core, the client and the service. Therefore, this configuration is 
not distributed. 
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b Each participant has their own key-pairs. The current simple approach is to 
generate three different key-pairs, one for each participant, with the follow- 
ing labels : client, core, and service, all within the same PSE. 

c Generate a basic attribute certificate, one for each pair of distinct partici- 
pants (i.e. client as issuer, core as subject and so on for all distinct combina- 
tions) which gives each participant arbitrary permission to perform 
operations. The PSE Manager can be used to conveniently generate these 
attribute certificates— it has access to all the keys that were generated. The 
PSE labels associated with the key-pairs can be used to refer to the keys 
within the certificates for convenience. 

d After it is generated, the important thing is that the certificate must be 
issued— this means it is signedby the Core itself. Thus, the certificate is 
issued by the Core, and having the Core again as its subject, with an all- 
powerful e-speak tag attribute: 

(net .espeak .method (*) {*) ) 

Again, the PSE Manager can perform this function of signing these certifi- 
cate by any one of the participants. 

Significantly, the PSE Manager GUI tool is generally standalone and does 
not need any prior configuration, i.e., it does not require any configuration 
before it can be used. 

To operate the core with security turned on, a security configuration file needs 
to be correctly loaded containing the appropriate attributes. The configuration 
file is more fully explained in the following sections. But a high-level snapshot 
goes as follows: 

a The configuration file is like a Java properties file and is typically named 
espeak . cf g. It is searched for in the current directory, the user's home 
directory or on the Java CLASSPATH. 

b A very simple espeakxfg file is shown on the next page. 



$Id: espeak. cfg,v 1.1.2.1.4.10 2000/05/16 07:17:42 ks Exp $ 
E-speak security properties file. 
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! Security properties. 



I Master flag controlling whether security is on or off. 
net . espeak. security .act ivate=on 

i Set a property prefix, 
@pref ix=net . espeak . security 

! Default name of the keystore file 
.pse . storef ile=securestore . txt 

I Gui mode runs a dialog for the passphrase, 
I .pse.mode=gui 

\ Passphrase mode looks for the passphrase property, 
.pse. mode - passphrase 

i Passfile mode looks for a file containing the passphrase property. 
! .pse. mode = passfile 

I Define the passphrase. 

.pse .passphrase ~ default passphrase 

I Define the default role (i.e. the default PSE key label), 
i. pse. role = client 

The following section discusses configuration files in more detail. 



The default configuration file is espeakxfg. The file is looked for in the following 
places: 

♦ config directory under e-speak home as defined by property 'espeakjiome' 
directory specified by property net.espeak.util.config.file', or current directory 
(from system property user.dir') if the property is not set directory specified by 
'user.home' system property as a system resource from the classpath Java 
system properties can be set on the Java command line using the syntax - 
Dproperty=value. 



Configuration files 
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• The name of the file to look for can be specified using the 
'net.espeak.util.config.file' property. The file defined by the property 
'net.espeak.utilconfig.masterls always loaded on top of all other files, if 
specified. The default for this property is null 

• All files found are loaded, in reverse order, with files found earlier being merged 
on top of properties from files found later. The format of the files is java 
properties file format, with the following additions. 

©pre f ix= <pre f ix > 

This sets a property prefix to apply to properties starting with a dot. For example: 

@pref ix=net . espeak . security 
.pse.mode = passphrase 

results in net . espeak . security . pse . passphrase being set to 'passphrase'. 
After it is set, a prefix remains in force until changed or set null 

@mode=<mode> 

If the <mode> is "override" (default) the values found in this file is used and all 
previous values are ignored. After the espeakxfg parser encounters a file with mode 
set to "override", no more files are parsed. If the mode is "merge" espeakxfg files 
are combined, if two files specify values for the same property, the value in the last 
file to be parsed is used. 

The name of the configuration file to look for can be set using the system property 

net . espeak . util . conf ig . file 
which has the default value espeak . cf g. 
If the system property 

net . espeak . ut il . conf ig .master 
is set, the file of that name is loaded on top of all other files found. 
The configuration is got by calling 

Configlntf Conf ig . getlnstance { ) 

which returns a reference to a static instance of the default configuration. Other 
files can be loaded directly if wanted, see util.Config for the API. Single property 
files can be loaded using ConfigProps. 
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Property file syntax 

A Java properties file contains property names and definitions. The name is 
separated from the definition by =\ Spaces before the property name and around 
the = are ignored. The value of the property extends to the end of line, and includes 
trailing spaces. Long property values can be broken across lines using \ to escape 
new lines. The characters ! and # introduce end-of line comments. The character : 
may be used as an alternative to =. 



Property conversion 

The class util.Convert provides methods to convert property strings to and from 
common types. The types int, boolean, and long are supported. The duration 
converters accept times in the format 12h3ml.001s and convert them to longs in 
milliseconds. Any zero component of a time can be omitted, and spaces may be 
included. A zero time can be stated as Os. 

The boolean converter accepts on, true, yes for true and off, false, no for false, 
regardless of case. 



Argument specifications 

The mapping or argument switches to properties can be defined using util. ArgSpec. 
This provides methods to process command-line arguments and map them onto 
properties in a configuration. 



Security properties 

The following are the properties supported by the security code. 

• Master flag controlling security: net . espeak. security . activate, 
boolean, default off. If this property converts to true, security is activated. 

• Property net . espeak . security . connec tOnContact , default off, controls 
whether secure sessions are established with newly encountered resources. 
When it is off, sessions are not established unless required (by 
SessionRequiredException) or created explicitly. 
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• PSE mode: net . espeak . security . pse .mode. Values: gui, passphrase, 
passfile. Default gui. If the mode is gui, a dialog is used to get the PSE 
passphrase. If the mode is passphrase the property 

net . espeak . security . pse . passphrase is used to get the passphrase 
(default null). If the mode is passfile the property 

net . espeak. security .pse .passfile (default passfile.txt) is used to get 
the name of a file which must contain a 

net . espeak . security .pse .passphrase property defining the 
passphrase. 

• PSE key file: net . espeak . security . pse . storef ile, default 
securestore.txt. Defines the name of the file containing public-private key pairs. 

• PSE role: net . espeak . security . pse . role, default client. Define the 
default role (symbolic PSE key name). 

• PSE file protection mode: 

net . espeak . security . pse . OSf ileprotect ion, default true. This 
property specifies whether local OS file protection should be applied and is 
supplied purely as an aid for testing purposes. For full security protection, this 
option should not be false. 

• Certificate file suffix: net . espeak . security . pse . cert file, default 
certs.adr. The value of this property is appended to the role name to get the 
name of the certificate file to load. If the role is client the certificate file 

is clientcerts.adr for example. 

• ACL file suffix: net . espeak . security . pse . aclf ile, default acl.adr. The 
value of this property is appended to the role name to get the name of the ACL 
file (trust assumptions) to load. If the role is client the ACL file 

is clientacl.adr for example. 

• Cipher suites: net . espeak . security . cipherSui tes. The value is a list of 
cipher suites in ADR syntax. The default is to use hmac, sha-1, and 128-bit 
blowfish. 

• Public key: net.espeaksecurity.pse.publicKeyAlgorithm using the values 
ELGAMAL and RSA. The default is ELGAMAL. Which one is being used can be 
found using neLespeak.security.util.PublicKeyLib. Call public static String 
getPublicKeyAlgorithm ( ) to find out. 
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We support two public key algorithms: RSA and El Gamal. The entire system must 
use one or the other, mixing is not supported. Public key classes are not loaded 
statically— they are loaded dynamically based on the configured algorithm. 

When El Gamal is configured, support for RSA is not be loaded, and if RSA data is 
encountered a NoSuchAlgorithmException is thrown. Which algorithm is used is 
defined by the property. 

Example espeak.cfg file 



E-speak security properties file. 



! Master flag controlling security. 

net .espeak. security. act ivate=on 
user .name- "John Doe" 



! Example time value. 

foo. timeout - 12h 3m .0001s 
! Set a property prefix. 

©pre f ix=net . e speak . security 

! Gui mode runs a dialog for the passphrase. 

I .pse.mode=gui 

! Passphrase mode looks for the passphrase property, 
.pse.mode = passphrase 

! Passfile mode looks for a file containing the passphrase property. 

!. pse.mode = passfile 
! Define the passphrase. 

.pse. passphrase = default passphrase 

J Define the default role (PSE key name). 

I .pse .role = foo 
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This chapter discusses firewall traversal using e-speak. We present how services 
can be accessed using e-speak while sitting behind a firewall. The proposed solution 
does not require modification of the existing security infrastructure.This offers a 
fast deployment but does not provide maximum security at the boundary. 



Architecture 

The architecture of the security system is presented in Figure 17. This architecture 
is very classic, the service is connected to the Engine Inside. The Engine Outside act 
as a proxy in the DMZ for the Engine Inside. Connections are established to the 
Engine Outside and then messages are routed to the Engine Inside. 

E-speak offers end-to-end security so the number of engines relaying messages is 
irrelevant. The security (Confidentiality, Integrity and Authentication) is 
established between the services and the clients. 




Service 
JESI 



M ► 

1 DMZ 



Figure 1 7 Security Architecture 
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When the service connects to the Engine Inside, it registers its metadata with the 
engine and establishes an outbound connection to the Engine Outside and exports 
this metadata. 

Firewalls usually offer means to establish outbound connections. HTTP proxies are 
one of them. They are widely deployed and offer through the HTTP Connect method 
a way to establish TCP connection to external systems. SOCKS V4 servers offer the 
same functionality but support stronger authentication mechanism. 

In order to achieve fast deployment of services with minimal architectural changes 
on the boundary, e-speak can be configured to use HTTP proxies or SOCKS servers. 

The requirements on the service provider side are as follows: 

• An HTTP proxy or SOCKS server must be present in the firewall. 

• A system in the DMZ must host an e-speak engine (Engine Outside). 
The requirements on the client side are as follows: 

• An HTTP proxy or SOCKS server must be present in the firewall. 

The HTTP proxy approach is possible only if the proxy allows for the HTTP 
Connect method on the Engine Outside port. 

These approaches uses either SOCKS V4 or HTTP Proxies to allow inbound 
connection. SOCKS V4 and HTTP Proxies have been created explicitly for outbound 
connections. Therefore these approaches have some drawbacks. Firstly, the service 
is available from the outside as long as the connection to the Engine Outside is up. 
This requires the connections to be long-lasting. Secondly, there is no control at the 
boundary because the Engine Outside is not capable of such functionality. The 
authentication and authorization is done at the service end-point, this means that 
unauthorized messages can potentially be sent to the inside services. 
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Deployment using HTTP proxies 

Figure 18 and Figure 19 presents classic deployment configuration using e-speak. 
G*WA QnparyB 




DVZ 



Figure 1 8 Client connecting directly to the Engine Outside 

In this scenario, the client connects directly to the Engine Outside through J-ESI. 
Follow these steps: 

1 Setup the client espeak.cfg file with the following properties: 
net.espeak.infra.cci.messaging.webproxyname=<proxy name> 
netespeak.infra.cci.messaging.webproxyport=<proxy port> 

This explicitly tells the client to open a connection through the web proxy. 

2 Setup the Engine Inside espeak.cfg file with the following properties: 
net.espeak.infra.core.connector.webproxyname=<proxy name> 
net.espeak.infra.core.connector.webproxyport=<proxy port> 

3 The service needs to explicitly export itself to the Engine Outside using its 
RemoteServiceManager. 
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Figure 19 Client connecting to the Engine Outside using a local engine 

In this scenario, the client connects to a local engine, which in turn connects to the 
Engine Outside. 

Follow these steps: 

1 Setup the Client Engine espeak.cfg file with the following properties: 
netespeak.infra.core.connector.webproxyname=<proxy name> 
netespeakinfra.corexormector.webproxyport=<proxy port> 

2 Setup the Engine Inside espeakxfg file with the following properties: 
net.espeak.infra.core.connector.webproxyname=<proxy name> 
netespeak.infra.core.connector.webproxyport=<proxy port> 

3 The service explicidy exports itself to the Engine Outside using its 
RemoteServiceManager. 

4 The client explicitly imports the service from the Engine outside using its 
RemoteServiceManager. 

NOTE: As explicit import and export are awkward, another alternative is to run an 
advertising service in the DMZ attached to the Engine Outside and use it to do the 
import and export implicitly. With this modification, the above scenario changes as 
follows: 



setup the Client Engine espeak.cfg file as above. 
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2 setup the Engine Inside espeakcfg file as above. 

3 The service is advertised in the advertising service in the DMZ, This leads to an 
implicit export from the Engine Inside to the Engine Outside. 

4 The client finds the service by looking up in the DMZ advertising service. This 
leads to an implicit import from the Engine Outside to the Client Engine. 

The scenario in Figure 19 can be modified similarly. 



Deployment using SOCKS Server 



The SOCKS protocol is supported internally by the VMs. No specific configuration 
is needed except for the VM configuration itself. 

Figure 20 shows one scenario where the SOCKS servers are used by the client and 
the service provider. 
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Figure 20 Using SOCKS servers 

Connector 

In some deployment cases, it is possible that installing the Engine Outside in the 
DMZ is perceived as too complicated or impossible. 
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E-speak introduces a new way for service providers to reach service consumers. 
The connector is the central point of the system. The connector is the Engine 
Outside moved in a DMZ of a trusted party. 

Figure 21 describe the deployment scenario for the connector. 
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Figure 21 Deployment of a connector in a trusted party's DMZ 

Company C is a trusted by Company B to host its services metadata. When 
Company B wants to expose its services to the outside, it connects the Engine 
Inside to the Engine Outside (Connector) and exports the description of the 
available services. 

When the clients wants to access a service, its connect to the connector and search 
for the given service and interact with it transparently. 

Clearly Company C needs to be trusted by the service provider because it exposes 
the service to the outside world. 

An example of the connector is the e-service village where service providers and 
services consumers can meet and establish relationship. 
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Currently system management in e-speak is undergoing a transition from a 
traditional network object model to a document exchange model Infrastructure 
and support for this model is still being developed and collaboration between 
parties on common schemas and mechanisms is in the early phases. This document 
therefore is very much work in progress and will remain as such until a variety of 
inter-related elements within e-speak become available and reach stability. 



Introduction 

This appendix describes the infrastructure and general philosophy of how web 
based management tools and an XML management interaction framework are 
provided in e-speak. 

System Management in e-speak currently consists of four things: 

• A managed service model. 

• XML Schemas and dialogs that enable management. 

• Client support for making services manageable. 

• A set of tools that provide access to the management services from the web. 

This document describes the first, third and fourth of the above with code 
examples. 



Developer Release X.03.03.00, September 2000 



169 



Managed Service Model 



Management 



Managed Service Model 

The managed service model is simply two concepts that underpin the manageability 
of e-speak services and e-speak clients: 

• Managed State: a defined service state embodying the life cycle of a service. 

• Managed Variable Table: sets of values that can be affected by a manager for the 
purposes of configuration and control. 

For this generic model to be useful, a client must map its service specific behavior 
onto this model and expose this model to a management agent. As we see later, the 
life cycle in the managed service model has many states, including initializing, 
ready, and running. It is entirely up to the service writer how these states are 
related to the service specific behavior. 

For example a service might have no need of an initialization phase but must 
instantaneously pass this state to conform to the model. A service may also be in 
various operational states while running, but running is the only way to express its 
condition from a management point of view. 

In summary then, the managed service model embodies a view of service behavior 
that is potentially common to many services. Therefore some custom management 
agents must deal with issues of service behavior that fall outside this model. 
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Managed Life Cycle 

The full state transition diagram is as follows: 




State Descriptions 

Initializing: The internal dynamic state of the service is being constructed, for 
example: a policy manager is being queried for configuration information and 
resources are being discovered via search recipes or yellow pages servers. When 
the service finishes this work it moves asynchronously into the ready or error 
states. 

Ready: The service is in a ready to run situation, this state is also equivalent to a 
stopped or paused state. 

Running: The service is running and responding to methods invoked on its 
operational interfaces. If an error occurs that implies that the service cannot 
continue to run, it should move into the error state. 

Error: The service has a problem and is awaiting management action on what to do 
next. 
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Closed: The service has removed/deleted much of its internal state and awaits 
either a coldReset or remove transitions. 

Inputs 

An input is the trigger that causes a state transition to occur In any given state, 
there is a defined set of permissible inputs that are available — only those that are 
depicted in the diagram as leaving the current state and connecting with the next 
state. To attempt to perform any other transition is illegal. Note that many inputs 
can have the same name (e.g. error) but there is no ambiguity as long as the 
originating state is different. 

Clients can provide any input with impunity. However, a management agent can 
request only provide external inputs. For example, the manager can reasonably 
request that a client perform a warm reset, but not to become ready, the client alone 
can provide this input— when it's internal initialization process has completed. 

The available inputs are as follows: 

start: move into the running state. Start to handle invocations on operational 
interfaces. 

stop: move into the ready state. Stop handling invocations on operational 
interfaces. 

ready: move into the ready state having finished initialization. 

error: move into the error state, this transition is valid from any state. 

shutdown: clean up any internal state required and move into the closed state. This 
transition should not cause the deregistering of resources from the repository. 

coldReset: cause a from complete reinitialization of the service and move into the 
initializing state. The only exemption is that resources that are already registered 
should not be reregistered. 

warmReset: cause a partial reinitialization of the service — retaining some of the 
existing service state move into the initializing state. 

remove: cause the service to remove itself from existence. Any non-persistent 
resources should be deregistered from the repository. 
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Managed Variable Tables 

A managed variable table is at it's simplest a table of name/string value pairs that 
exist within the client but to which a manager has some level of access. Thus, a 
management agent can control those aspects of a services behavior that is affected 
by those variables to which it has access. 

There is a degree of configurability associated with managed variables and their 
variables that permit something more sophisticated than the simple get and set 
operations one would expect to find. 

Each table itself has a name to distinguish it from other tables. As we shall see later, 
the managed service model itself provides for two such tables. 

The most simple usage case for a managed variable would be for a variable which 
the management agent has only read access but which the client varies as 
necessary. The manager can monitor the changes (see events later) such that an 
operator who understands the meaning of this variable (e.g. 
secondsToDetonation) might gain some information. 

The next level of sophistication is to enable the operator to affect the services 
behavior by modifying the value of the variable. However, some service 
configuration is only of practical use during initialization (e.g. some resource 
allocation parameter) . Knowing the instantaneous value of such a variable does not 
explain the clients behavior (if it had been changed) and modifying it has no effect. 

To account for this, a managed variable can have one or more values. The 
compulsory value is its "live" value i.e. the value that is contributing to its current 
behavior. In the simplest case this is the only value that a variable has. 

However, a variable can have other values, which are in effect "scheduled" values 
and associated with the various reset operations in the client s life cycle. 
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For example, consider the following managed variable found in some unreasonably 
hazardous device: 



Variable Name 


Values 




Value Condition 


Remote Access 


Value 


secondsToDetonation 


Live Value 


Read Only 


42 




On Cold Reset 


Read Only 


50 




On Warm Reset 


Read/Write 


60 



Let s assume it takes some operator three minutes to reach safety or the devices off 
switch. The operator brings up his management console and notices that the 
current value of secondsToDetonation is 42, and dropping. Clearly the 
circumstances are undesirable: the current value does not provide long enough to 
escape without injury. Increasing this value to three minutes or more and running 
away is ideal but the value is read only. 

Glancing down the list the operator notices that there are two reset values and 
performs a cold reset. After the device has re-booted, and re-loaded the counters 
default initial value (perhaps in ROM) it promptly starts counting down from 60 
seconds. Still not good but at least the operator can try and stay up all night 
performing cold resets every 59 seconds or less. 

Having bought some time the operator looks a little more closely at the variable. 
The warm reset value is writable. Now the operator can set this to thirty minutes 
and go and disconnect the power supply. 

Clearly a contrived example but it does demonstrate how relatively complex 
interactions between initialization, configuration value and behavior can be 
represented. 

A more likely scenario is where a client has a set of variables that configure its 
behavior that must all be changed synchronously. A management agent can modify 
its warm reset values at its leisure (being denied access to the live values) and then 
perform a warm reset. 

There is a restriction on variable table usage: 
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Uniqueness: names in a variable table must be unique within that table. It is not 
possible to implement lists by having many entries with the same name. 

Configuration Parameter Table 

The configuration parameter table is an instance of a managed variable table with a 
reserved name that identifies it as such. The table holds generic configuration data 
for the client. 

Resource Table 

The resource table is another instance of a managed variable table, identical in 
behavior to the configuration parameter table except that the names in the client's 
table refer to other services with which the client has some relationship. For 
example, if a particular client makes use of a mail service then this relationship can 
be made visible to a management agent through the resource table. Thus a 
management agent might reconfigure the client to use an alternative but equivalent 
service. While there might seem no obvious need to separate out this particular 
aspect of configuration, doing so makes it possible for a management agent to 
discover the topology and integrity of a network of connected services without the 
need for service specific interpretation of the variable table (all entries in the 
resource table are resources). 

The name used for an entry in a resource table can be any symbolic name the client 
chooses, while the value must be the valid e-speak URL of the actual service. 

System Management Events 

Events can be considered as notifications of some significant occurrence. In the 
context of system management, events must exist to convey notification of some 
change of state with regards the Managed Service Model. The following events are 
therefore defined: 

ManagedServiceStateChange: This event conveys information regarding some 
managed service state transition to any interested management agent. In this case, 
the event is the name of the input provided to the management life cycle FSM. 
Clearly, the management agent must have known what the previous state was in 
order that this information be meaningful. 
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ManagedVariableValueChange: This event conveys information regarding a 
value modification in a clients configuration or resource table. 



Managed Service Programmers Guide 

Writing a Simple Managed Service 

In this section we create a simple managed service 1 . 

First, to get familiar with the tools we look at the most minimal Java program that 
is "manageable" through e-speak. 

A Minimal Service 

Consider the following program: 

import 

net . espeak .management . managedservice . simplemanagedservice . SimpleXMLManaged 
Service; 

import net . espeak . infra . cci . except ion . ESExcept ion ; 
import net . espeak . jesi .management . Service Context ; 

public class VerySimpleExample extends SimpleXMLManagedService { 
public static final String SERVICE_NAME = "VerySimpleService" ; 
public static final String LOCALHOST = "127.0.0.1"; 
public static final int COREPORT = 12346; 

public VerySimpleExample () throws ESException { 

super (new ServiceContext { LOCALHOST, COREPORT, "tcp") , SERVICE_NAME) ; 
makeManageable () ; 

} 

protected void stateChangeOccurred {String transition, String oldState, 
String newState) {} 

protected void resourceChangeOccurred {String resource, String oldValue, 
String newValue) {} 

1 For reference, a fully working example of a managed service is supplied in: 
net.espeak.management.managedservice.simplemanagedservice.ExampleService 
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protected void variableChangeOccurred (String variable, String oldValue, 
String newValue) {} 

protected boolean acceptStateChange (String transition, String oldState, 
String newState) { 
return true; 

} 

protected boolean acceptVariable Change (String variable, String oldValue, 
String newValue) { 
return true; 

} 



protected boolean acceptResourceChange (String resource, String oldValue, 
String newValue) { 
return true; 

} 

public static void main (String [] args) { 
try { 

new VerySimpleExample () ; 
} catch (ESException e) { 
e.printStackTraceO ; 

} 

} 

} 

VerySimpleExample (above) subclasses SimpleXMLManagedService, a utility class 
that in most circumstances provides adequate manageability support. We consider 
more sophisticated examples later. 

For now let's just consider the constructor: 

public VerySimpleExample {) throws ESException { 

super (new ServiceContext {LOCALHOST, COREPORT, "tcp"), 

SERVICE_NAME) ; 

makeManageable () ; 

} 

First, the super class is initialized with a connection to the local core 2 , second the 
makeManageableO method makes the service visible to any management agents. 
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Managing the Service 

We are now ready to try the program out, but first we must have a core running. For 
convenience, there is a configuration file which starts all the services required for 
management Go to your e-speak installation directory and type: 

espeak -i config\management\xmlmanagement.ini 
After a few moments, run a web browser and go to: 
http://127.0.0.1:2000/servlet/services 
You see a screen similar to the following: 




e-speak Generic Web Services 



A 

' BkIbss 



2 For simplicity, the host and port are hardwired into the example and assume the core is run- 
ning on the local host and uses port 12346, which is the value in the default version of xmlman- 
agement.ini. These values can be changed but the host must be the host name/IP address of a 
host running a core and the port number must match that used by the core. 
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This is a list of the visible "web enabled" services on your local core, in this case the 
services started by xmlmanagement.ini. 

Click the Service Manager link and you see the following page: 




This is the main service manager screen and displays a list of all the manageable 
services to be found on your local core. 

Note that while we call this the Service Manager, it should be remembered that it is 
clearly a web based interface onto the actual Service Manager. While the service 
manager is aware of the status of services in real time, the browser is not; so you 
should use the "Update" buttons provided to keep the display current For related 
reasons, navigate between Service Manager screens using the links provided and 
avoid the use of the back button, particularly if you actively interacting with the 
services through the service manager. 
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Now we are ready to run VerySimpleExample. Compile the program and run it. 
After a few moments go back to the service manager screen and click the Update 
button. Now you see your program available for management: 




Click the Management link next to VerySimpleService: 
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This is the management page for your service. At the moment, your service is not 
being managed so click the Manage Service button: 



Developer Release X.03.03.00, September 2000 



181 



Managed Service Programmers Guide 



Management 




e-speak Service Manager 



Service: 1S4 VerySimpIeService 




So what does this mean? Earlier in the document we discussed the concept of the 
Managed Life Cycle of a service. If you look back at the state diagram, you see that 
the start state was initializing. Because we have not changed service state in our 
program, we remain in this state forever. 



Changing Service State 

Now lets try something slightly more interesting. Consider this next program, very 
similar to the last: 

import 

net . espeak . management .manage dser vice . simplemanagedservice . SimpleXMLManaged 
Service; 

import net .espeak. infra. cci . exception. ESExcept ion; 
import net .espeak. jesi .management -ServiceContext ; 
import 

net . espeak .management . managedservice .managedstate . ManagedServiceStateMachi 
ne; 
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public class VerySimpleExample2 extends SimpleXMLManagedService { 
public static final String SERVICEJJAME = n VerySimpleService2" ; 
public static final String LOCALHOST = "127.0.0.1"; 
public static final int COREPORT = 12346; 

public VerySimpleExample2 () throws ESException { 

super (new ServiceContext {LOCALHOST, COREPORT, "tcp") , SERVICE_NAME) ; 
makeManageable { } ; 

^ performTransition(ManagedServiceStateMachine.TO_READY_TRANSITION) ; 

protected void stateChangeOccurred {String transition, String oldState, 
String newState) {} 

protected void re sourceChangeOccurred{ String resource, String oldValue, 
String newValue} {} 

protected void variableChangeOccurred{ String variable, String oldValue, 
String newValue) {} 

protected boolean acceptStateChange (String transition, String oldState, 
String newState) { 
return true; 

} 

protected boolean acceptVariableChange {String variable, String oldValue, 
String newValue) { 
return true; 

} 



protected boolean acceptResourceChange (String resource, String oldValue, 
String newValue) { 
return true; 

} 

public static void main (String [] args) { 
try { 

new VerySimpleExample2 {) ; 
} catch (ESException e) { 
e .printStackTrace ( ) ; 

} 

} 

} 

Here, the only real difference is in the constructor, where we have added the line: 
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performTransition(ManagedServiceStateMachine.TO READY TRANSITI 
ON) ; 

Have another look at the service state diagram and you see an internal transition 
taking the service to the Ready state. The line of code, above, causes this transition 
to occur. Lets compile and run this program to see what happens when viewed 
through the Service Manager. 

After the VerySimpleService2 is running, go to back to the Service Manager and 
click the All Services link and click the Update button. Your new program is 
available for management: 





As before, go to the Services Management screen and click the Manage Service 
button. You see the following: 
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e-spea k smic« ftte^ 




The state of your service is now listed as ready and three new buttons have 
appeared. Looking back at the service state diagram, you can see that when a 
service is in the Ready state a manager can request that it can start, stop or perform 
a warm reset. Click the Start and the following screen appears: 
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Clicking the Stop button takes you back to the previous screen. All very interesting, 
but how does this relate to the program we're running? At the moment the program 
isn't affected at all by these management changes. 

Adding Custom Service Behavior 

So far the service doesn't do anything interesting, so let's take a look at how we can 
improve the situation: 

import 

net .espeak. management .managedservice . simplemanagedservice.SimpleXMLManaged 
Service ; 

import net .espeak. infra . cci . exception. ESExcept ion; 
import net. espeak. jesi .management. ServiceContext ; 
import 

net . espeak .management .managedservice .managedstate .ManagedServiceStateMachi 
ne; 
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public class VerySimpleExample3 extends SimpleXMLManagedService 
implements Runnable { 

public static final String SERVI CE_NAME = "Very Simple Service 3" ; 
public static final String LOCALHOST = " 127 . 0 . 0 . 1" ; 
public static final int COREPORT = 12 346; 
protected boolean running = false; 
protected Thread runThread = null; 

public VerySimpleExample3 () throws ESException { 

super (new ServiceContext (LOCALHOST, COREPORT, "tcp" ), SERVI CE_NAME} ; 
makeManageableO ; 

performTransition(ManagedServiceStateMachine.TO_READY_TRANSITION) ; 



public void run() { 
while (true) { 

synchronized (runThread) { 
if ('running) { 
return; 

} 

} 

System. out. print In ("Running " + System . currentTimeMi 11 is (}) ; 
try { 

Thread. sleep(lOOO) 
} catch (InterruptedException e} {} 

} 1 

protected synchronized void stateChangeOccurred (String transition, 
String oldState, String newState) { 

if (newState. equals (ManagedServiceStateMachine.RUNNING_STATE) ) { 

running = true; 

runThread = new Thread (this) ; 

runThread. start ( ) 
} else if (runThread i= null) { 

synchronized (runThread) { 
running = false; 

} 

try { 

runThread . j oin ( ) ; 
} catch (InterruptedException e) {} 
runThread = nul 1 ; 

} 

} 

protected void resourceChangeOccurred (String resource, String oldValue, 
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String newValue) {} 

protected void variableChangeOccurred (String variable, String oldValue, 
String newValue) {} 

protected boolean acceptStateChange {String transition, String oldState, 
String newState) { 
return true; 

} 

protected boolean acceptVariable Change {String variable, String oldValue, 
String newValue) { 
return true; 

} 

protected boolean acceptResourceChange (String resource, String oldValue, 
String newValue) { 
return true; 

} 

public static void main (String [] args) { 
try { 

new VerySimpleExample3 { ) ; 
} catch {ESException e) { 
e . pr intStackTrace { ) ,- 

} 

} 

} 

Here we have given the program a runnable thread and added some code to the 
stateChangeOccurredO method. This method is called after any change of 
service state. If you compile and run this program, then when you start and stop it 
from the Service Manager you also see the thread started and stopped. 

Managing Variables 

It is also possible to manage the data within your service. Consider the next 
derivative of the service: 

import 

net . espeak .management .managedservice . s imp lemanagedservice .Simp leXMLManaged 
Service; 

import net , espeak . infra . cci . exception . ESException ; 
import net .espeak. jesi .management .ServiceContext; 
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import 

net . espeak. management .managedservice .managedstate.ManagedServiceStateMachi 
ne; 

public class VerySimpleExample4 extends SimpleXMLManagedService 
implements Runnable { 

public static final String SERVI CE_NAME = " VerySimpleService4" ; 

public static final String LOCALHOST = "127.0.0.1"; 

public static final int COREPORT = 12346; 

public static final String MES SAGE_VAR = "Message"; 

protected boolean running = false; 

protected Thread runThread = null; 

protected String message = "running"; 

public VerySimpleExample4 () throws ESException { 

super {new Service Context (LOCALHOST, COREPORT, "tcp"), SERVI CE_NAME ) ; 
createVariable(MESSAGE_VAR, message, true); 
makeManageable ( } ; 

perf ormTransition (ManagedServiceStateMachine .TO_READY_TRANSITION) ; 



public void run() { 
while (true) { 

synchronized (this) { 
if (I running) { 
return; 



protected synchronized void stateChangeOccurred (String transition, 
String oldState, String newState) { 

if (newState. equals (ManagedServiceStateMachine. RUKNING_STATE) } { 

running = true; 

runThread = new Thread (this) ; 

runThread . start ( ) ; 
} else if (runThread 1= null) { 



System. out .print In (message + " 



System. currentTimeMillis ( ) ) ; 



try { 

Thread. sleep (1000) ; 
} catch ( Interrupt edExcept ion e) {} 



running 



= false; 



try { 



runThread . j oin { ) ; 
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} catch (InterruptedException e) {} 
runThread = null; 



} 



protected void resourceChangeOccurred{ String resource, String oldValue, 
String newValue) {} 

protected synchronized void vari ableChange Occurred ( String variable, 
String oldValue, 

String newValue) { 

if (variable .equals (MESSAGE VAR) ) 

{ 

message = newValue; 

} 

} 

protected boolean acceptStateChange (String transition, String oldState, 
String newState) { 
return true; 

} 

protected boolean acceptVariableChange (String variable, String oldValue, 
String newValue) { 
return true; 

} 

protected boolean acceptResourceChange (String resource, String oldValue, 
String newValue) { 
return true; 

} 

public static void main (String [] args) { 
try { 

new VerySimpleExample4 { ) ; 
} catch (ESException e) { 
e .printStackTrace 0 ; 

} 

} 

} 

Here we have added a normal class variable called "message" which we print in the 
run method. What we have also done in the constructor is create a Managed 
Variable that informs the system manager that such a variable exists, i.e. what it's 
name is, what it's initial value is and whether it can be remotely modified: 
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create Variable {MESSAGE_VAR, message, true) ; 

This is sufficient to make the variable visible to the Service Manager, but we also 
want the our program to reflect changes to the value of this variable made by the 
service manager. To achieve this we have added some code to the 
variableChangeOccurredO method. This code simply verifies which Managed 
Variable has changed and ensures that the appropriate action is taken. In this case, 
it simply updates the local message variable. 

Viewing this service through the Service Manager looks as follows: 




You can see that in addition to the service state, our managed variable is visible. 
Clicking the variable name opens the following screen: 
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Here you can change the value of the variable. Try changing the value and observe 
the output of your service change while it is running. 

Dynamic Variables 

So now we can change the value of our variables remotely, but what would happen 
if we changed the value locally? If the management system is to know the state of 
your service from second to second then obviously it needs to be told. This next 
example uses an additional managed variable, which is updated locally: 

import 

net . espeak . management . managedservice . s implemanagedservice . S impleXMLManaged 
Service; 

import net .espeak. inf ra .cci . exception. ESExcept ion; 
import net .espeak. jesi .management .ServiceContext ; 
import 

net . espeak .management . managedservice . manage dst ate . ManagedServiceStateMachi 
ne; 
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import java .util .Date; 

public class VerySimpleExampleB extends SimpleXMLManagedService 
implements Runnable { 

public static final String S ERVI CE_NAME = "VerySimpleServiceS" ; 
public static final String LOCALHOST = "127.0.0.1"; 
public static final int COREPORT = 12346; 
public static final String MESSAGE_VAR = "Message"; 
public static final String TIME_VAR = "Time"; 
protected boolean running = falser- 
protected Thread runThread = null; 
protected String message = "running"; 

public VerySimpleExampleB () throws ESException { 

super (new ServiceCon text (LOCALHOST, COREPORT , "tcp") , SERVICE_NAME) ; 
c r ea teVari able (MESS AGE_VAR, message, true); 
createVariable (TIME_VAR, new Date O.toString {), false); 
makeManageable () ; 

perf ormTransition (ManagedServiceStateMachine .TO_READY_TRANSITION) ; 

} 

public void run() { 
while (true) { 

synchronized (this) { 
if ('running) { 
return; 

} 

System. out .println (message + " " + 
System. currentTimeMill is { ) ) ; 

super .setVariable(TIME_VAR, new Date O.toString 0); 

} 

try { 

Thread. sleep (100 0) ; 
} catch (InterruptedException e) {} 

} 

} 

protected synchronized void stateChangeOccurred (String transition, 
String oldState, String newState) { 

if (newState. equals (ManagedServiceStateMachine. RUNNING_STATE) ) { 

running - true; 

runThread = new Thread (this) ; 

runThread . start ( ) ; 
} else if (runThread i~ null) { 
running = false; 

try { 
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runThread . j oin { ) ; 
} catch {InterruptedException e) {} 
runThread = null; 

} 

} 

protected void re sourceChangeOccurred (String resource, String oldValue, 
String newValue) {} 

protected synchronized void variableChangeOccurred( String variable, 
String oldValue, 

String newValue) { 

if (variable. equals (MESSAGE_VAR) ) 

{ 

message = newValue; 

rn } 

I 1 

protected boolean acceptStateChange (String transition, String oldState, 
UJ String newState) { 

jlf return true; 

nl protected boolean acceptVari able Change (String variable, String oldValue, 

String newValue) { 
return true; 

M } 

!1I protected boolean acceptResourceChange {String resource, String oldValue, 

ij| String newValue) { 

f?\ return true; 

li ) 

M public static void main (String [] args) { 

try { 

new VerySimpleExampleS 0 ; 
} catch (ESException e) { 
e . print StackTrace ( ) ; 

} 

} 

} 

Here we have added a new Managed Variable that represents the time, which we 
update in the run method of our service. Viewing our service through the Service 
Manager now looks something like this: 
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Here we can see our new (read only) Time variable. Now when you start the service, 
each time you click the Update button, you see the most recent value of the time 
variable. 
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There are three classes of checked exceptions that can be thrown by the J-ESI APIs. 
They are: 

• ESInvocationException 

• ESServiceException 

• ESLibException 



ESInvocationException 

ESInvocationException is thrown usually when the engine (or the core) 
detects a problem with the request. Examples of such exceptions are quota 
exhausted or stale entry. 

• QuotaExhaustedExcept ion, as the name implies, is thrown when there is no 
more space in the allocated quota of the client to hold any entries. 

• staleEnt ryAccessExcept ion is thrown when the service which the request 
is destined for is stale and the request cannot be delivered to the service. 

For a detailed listing of all ESInvocationExceptions, see "Exceptions" in 
Chapter 8 of the e-speak Architectural Specifications, version 3.01. 



Developer Release X.03.03.00, September 2000 



197 



ESServiceException 



Exceptions 



ESServiceException 

ESServiceException happens when the core has delivered a request to the 
service, but the service has detected an error with the request. Some of the service 
exceptions thrown by core services are, LookupFailedException thrown by 
the finder service when any lookup fails, InvalidNameException thrown by the 
folder service when any of the names passed is invalid. 

Any user specific exception defined also should extend ESServiceException. 
For example, if some one writes a printer service which can throw a 
Outof PaperException, this should extend ESServiceException. 

For a detailed listing of all these exceptions, see "Exceptions" in Chapter 8 of the e- 
speak Architectural Specifications, version 3.01. 



ESLibException 

ESLibException is usually thrown by the library itself when it has detected an 
error condition. For example, CoreNotFoundExcept ion is thrown when no core 
exists in the hostname :portnumber specified. 

Apart from these exceptions, ESRuntimeException is thrown to indicate a 
runtime failure. ESLibRuntimeException is a subclass of 
ESRuntimeException and is thrown in unexpected behavior conditions. 
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ATTY DOCKET NO.: 10001279 

(M-8674 US) 



Appendix C 



test 

Volume in drive E is 001206_1632 
Volume Serial Number is 33CE-90D1 



Directory of E:\ 



12/06/00 04:32p <DIR> 
12/06/00 04:32p <DIR> 

12/06/00 04:33p <DIR> e-speak-src_9912 

3 File(s) 0 bytes 



Directory of E:\e-speak-src_991217 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> platform 

3 File(s) 0 bytes 



□Directory of E:\e-speak-src_991217\platform 

42/06/00 04:33p <DIR> 

UJ2/06/00 04:33p <DIR> 

132/06/00 04:33p <DIR> ES 

l|? 3 File(s) 0 bytes 

Directory of E:\e-speak-src_991217\platform\ES 



i=42/06/00 


04:33p 


<DIR> 






1112/06/00 


04:33p 


<DIR> 






i3l2/06/00 


04:33p 


<DIR> 




bin 


$12/06/00 


04:33p 


<DIR> 




conf ig 


512/15/99 


04:00p 




54,294 


configure 


2.2/15/99 


04:00p 




10,314 


configure . in 


12/07/99 


04:25p 




53 


configure . nt 


12/06/00 


04:33p 


<DIR> 




contrib 


12/07/99 


04:25p 




15,413 


COPYING 


12/07/99 


04 :25p 




23,237 


COPYING. LIB 


12/06/00 


04:33p 


<DIR> 




CVS 


12/06/00 


04:33p 


<DIR> 




extern 


12/07/99 


04:25p 




20,163 


HowTo . html 


12/15/99 


04:00p 




4,224 


include. mk. in 


12/15/99 


04:00p 




13,149 


Makefile . in 


12/07/99 


04:25p 




1,509 


make . rules 


12/06/00 


04:33p 


<DIR> 




samples 


12/06/00 


04:33p 


<DIR> 




src 


12/06/00 


04:33p 


<DIR> 




tutorial 




19 


File (s) 


142,356 bytes 
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V test 

Directory of E:\e-speak-src_991217\platform\ES\bin 



12/06/00 


04 


:33p 


<DIR> 




m 


12/06/00 


04 


:33p 


<DIR> 




. . 


12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/07/99 


04 


:25p 




2,040 


envmake 


12/07/99 


04 


:25p 




2, 007 


envmake .bat 


12/07/99 


04 


:25p 




2, 673 


envset 


12/07/99 


04 


:25p 




27 


eshome . bat 


12/07/99 


04 


:25p 




7,292 


genenv.pl 


12/15/99 


04 


:00p 




17, 909 


install .pi 


12/07/99 


04 


:25p 




35,269 


run.pl 



10 File(s) 67,217 bytes 



Directory of E:\e-speak-src_991217\platform\ES\bin\CVS 



12/06/00 
12/06/00 
42/16/99 
"$2/16/99 
'0J2/16/99 
£2/16/99 



04:33p 
04:33p 
06:18p 
06:17p 
06:17p 
06:17p 
6 



<DIR> 
<DIR> 



File (s) 



321 Entries 
31 Repository 
4 6 Root 

84 6 Template 
1,244 bytes 



^Directory of E:\e-speak-src_991217\platform\ES\config 



,12/06/00 


04 


: 33p 


<DIR> 






1,12/06/00 


04 


:33p 


<DIR> 






1112/06/00 


04 


:33p 


<DIR> 




CO 


32/07/99 


04 


: 25p 




22 


col 


12/07/99 


04 


:25p 




22 


co2 


:12/07/99 


04 


:25p 




22 


codef 


32/07/99 


04 


:25p 




133 


core . ini 


12/0.6/00 


04 


:33p 


<DIR> 




CVS 


12/07/99 


04 


:25p 




1,039 


default . ini 


12/07/99 


04 


:25p 




149 


espeak_ldap . prop 


12/06/00 


04 


: 33p 


<DIR> 




management 


12/07/99 


04 


:25p 




25 


multiplecf . cf g 


12/07/99 


04 


:25p 




510 


repository . ini 


12/07/99 


04 


:25p 




17 


sample . cfg 



14 File(s) 



1, 939 bytes 



Directory of E:\e-speak-src_991217\platform\ES\config\co 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/07/99 04:25p 22 col 

12/07/99 04:25p 22 colO 
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test 



12/07/99 


04:25p 


22 


col . stress 


12/07/99 


04:25p 


22 


co2 


12/07/99 


04:25p 


22 


co2 . stress 


12/07/99 


04:25p 


22 


co3 


12/07/99 


04:25p 


22 


co3 . stress 


12/07/99 


04:25p 


22 


co4 


12/07/99 


04:25p 


30 


co.SVEN.OMNIBOOKl 


12/07/99 


04:25p 


22 


co4 . stress 


12/07/99 


04:25p 


22 


co5 


12/07/99 


04:25p 


30 


CO. SVEN. OMNI BOOK 


12/07/99 


04:25p 


22 


co5 . stress 


12/07/99 


04:25p 


22 


co6 


12/07/99 


04:25p 


24 


co . PHIL . OMNI 3 


12/07/99 


04:25p 


22 


co7 


12/07/99 


04:25p 


22 


co8 


12/07/99 


04:25p 


22 


co 9 


12/07/99 


04:25p 


24 


co. PHIL. OMNI 4 


12/07/99 


04:25p 


32 


CO . CHIA. CHOWCHOW1 


,42/07/99 


04:25p 


24 


co.PHIL.IUl 


12/07/99 


04:25p 


24 


co.PHIL.IU24 


•£2/07/99 


04:25p 


33 


co . SVEN . KAYAK1 


hl2/07/99 


04:25p 


22 


co . CHIA. localhost 


;i2/07/99 


04:25p 


22 


CO.MYC03 


312/07/99 


04:25p 


24 


co. PHIL. OMNI 2 


(112/07/99 


04:25p 


32 


co.CHIA.CHOWCHOW 


12/07/99 


04:25p 


24 


co.PHIL.IU23 


,12/07/99 


04:25p 


33 


co . SVEN . KAYAK 


,,12/07/99 


04:25p 


22 


CO.MYC02 


,112/07/99 


04:25p 


24 


co. PHIL. OMNI 


$2/07/99 


04:25p 


24 


co.PHIL.IU22 


ifl2/07/99 


04:25p 


22 


CO.MYCOl 


S2/07/99 


04:25p 


30 


co . CHIA. OMNIBOOK1 


i-2/07/99 


04:25p 


24 


co.PHIL.IU2 


12/07/99 


04:25p 


22 


co.MYCO 


12/07/99 


04:25p 


30 


CO.CHIA.OMNIBOOK 


12/06/00 


04:33p <DIR> 




CVS 




40 File(s) 


906 bytes 



Directory of E:\e-speak-src_991217\platform\ES\config\co 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File (s) 



1,736 Entries 
37 Repository 
4 6 Root 
84 6 Template 
2,665 bytes 
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test 

Directory of E:\e-speak-src_991217\platform\ES\config\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 420 Entries 

12/16/99 06:18p 32 Entries. Log 

12/16/99 06:18p 34 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

7 File(s) 1,378 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\conf ig\raanagement 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:25p 22 co2.dat 

12/06/00 04:33p <DIR> CVS 

12/06/00 04:33p <DIR> html 

42/07/99 04:25p 980 management.ini 

J 6 File(s) 1,002 bytes 

Uj Directory of E: \e-speak-src_991217\platf orm\ES\conf ig\management\CVS 

[J12/06/00 04:33p <DIR> 
1112/06/00 04:33p <DIR> 

=12/16/99 06:18p 98 Entries 

,12/16/99 06:18p 14 Entries. Log 

.12/16/99 06:18p 45 Repository 

1112/16/99 06:18p 46 Root 

3.2/16/99 06:18p 846 Template 

3J 7 File(s) 1,049 bytes 

gl Directory of E: \e-speak-src_991217\platf orm\ES\conf ig\management\html 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/06/00 04:33p <DIR> images 

12/07/99 04:25p 687 main.html 

12/07/99 04:25p 882 servlet . properties 

6 File(s) 1,569 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\conf ig\management\html 
\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 104 Entries 
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12/16/99 06:18p 
12/16/99 06:18p 
12/16/99 06:18p 
12/16/99 06:18p 

7 File(s) 



test 

16 Entries. Log 
50 Repository 
4 6 Root 
846 Template 
1,062 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\conf ig\management\html 



\images 












12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 






12/07/99 


04 


:25p 




6,840 


Closed. gif 


12/06/00 


04 


:33p 


<DIR> 




CVS 


12/07/99 


04 


:25p 




6, 910 


Error . gif 


12/07/99 


04 


:25p 




6,852 


Initializing 


12/07/99 


04 


:25p 




5,058 


logo. gif 


12/07/99 


04 


:25p 




6,897 


Ready. gif 


12/07/99 


04 


:25p 




6,880 


Running . gif 



q 9 File(s) 39,437 bytes 

^Directory of E : \e-speak-s rc_9 91217 \platform\ES\config\management\html 
j,| images \CVS 

^2/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 288 Entries 

,12/16/99 06:18p 57 Repository 

iJ.2/16/99 06:18p 46 Root 

,■£2/16/99 06:18p 846 Template 

21 6 File(s) 1,237 bytes 

^Directory of E:\e-speak-src_991217\platform\ES\contrib 



12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 


browser 


12/06/00 


04 


:33p 


<DIR> 


CVS 


12/06/00 


04 


: 33p 


<DIR> 


gsysmon 


12/15/99 


04 


:00p 




245 Makefile 


12/06/00 


04 


: 33p 


<DIR> 


sysmon 


12/06/00 


04 


: 33p 


<DIR> 


vf s 



8 File(s) 245 bytes 

Directory of E:\e-speak-src_991217\platform\ES\contrib\browser 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:25p 3,280 Browser. java 
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test 

12/06/00 04:33p <DIR> core 

12/06/00 04:33p <DIR> CVS 

12/15/99 04:00p 991 Makefile 

12/06/00 04:33p <DIR> tree 

12/06/00 04:33p <DIR> ui 

12/06/00 04:33p <DIR> util 

9 File(s) 4,271 bytes 

Directory of E: \e-speak-src_991217\platform\ES\contrib\browser\core 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:40p 12,861 CoreBrowser . java 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:40p 390 Makefile 

5 File(s) 13,251 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\contrib\browser\core\C 

H2/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 101 Entries 

42/16/99 06:18p 48 Repository 

$2/16/99 06:18p 46 Root 

i|2/16/99 06:18p 846 Template 

6 File(s) 1,041 bytes 

ftl Directory of E : \e-speak-src_9 91217 \platform\ES\contrib\browser\CVS 

S2/O6/OO 04:33p <DIR> 
12/06/00 04:33p <DIR> 

32/16/99 06:18p 97 Entries 

12/16/99 06:18p 54 Entries. Log 

12/16/99 06:18p 43 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

V File(s) 1,086 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\contrib\browser\tree 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:25p 246 a.gif 

12/07/99 04:25p 247 alert . red. gif 

12/07/99 04:25p 242 alert.black.gif 

12/07/99 04:25p 2,326 apache_pb.gif 

12/07/99 04:25p 1,573 AttributePropertyNode . j ava 
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12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

,12/07/99 04:25p 

-12/06/00 04:33p 

:*|2/07/99 04:25p 

"12/07/99 04:25p 

^2/07/99 04:25p 

;Jt2/07/99 04:25p 

:jt2/07/99 04:25p 

1^2/07/99 04:25p 

r l2/07/99 04:25p 

"12/07/99 04:25p 

■^2/07/99 04:25p 

42/07/99 04:25p 

32/07/99 04:25p 

32/07/99 04:25p 

S2/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/15/99 04:00p 

12/07/99 04:25p 



test 

2,096 AttributeNode. java 
216 back.gif 
205 ball.red.gif 
233 ball.gray.gif 

2,558 BaseNode. java 
246 binary.gif 

246 binhex.gif 
148 blank.gif 
308 bomb.gif 
251 boxl.gif 
268 box2.gif 

247 broken.gif 

235 burst.gif 

242 c.gif 

1,038 compressed.gif 
246 comp.gray.gif 
251 comp.blue.gif 
214 continued.gif 
1,933 CoreManagedNode. java 
<DIR> CVS 

225 dir.gif 
163 down.gif 
238 dvi.gif 
1,621 ESContractNode. java 
1,619 ESNameFrameNode. java 
1,729 EsrlNode. java 
1,436 ESVocabularyNode . java 

236 f.gif 

225 folder.gif 

243 folder.sec.gif 

242 folder.open.gif 

219 forward.gif 
221 generic.gif 
249 generic.sec.gif 

220 generic.red.gif 
223 hand.up.gif 
217 hand.right.gif 

11,977 icon.sheet.gif 
274 imagel.gif 
309 image2.gif 
28 6 image3.gif 
1,467 InboxNode . java 
268 index.gif 
276 layout.gif 
172 left.gif 
249 link.gif 
969 Makefile 

243 movie.gif 
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test 



12/07/99 


04 : 25p 


237 


n cH "F 
p . y j- j_ 


12/07/99 


04 • 25d 


Z. -J X 


n^frh m* "F 

W QU^il * U J L 


12/07 /99 


04 • 25n 


24 9 

Z. T ^ 


nH "F rr i *F 


12/07 /99 


04 • 25n 


188 

~L U (J 


r>-i pf) rH "F 


12/07/99 


04 * 25n 


1 98 


n-i pi rf "i "F 


12/01 /99 


04 • 2 Sn 


1 98 

xz? o 


P-LtSZ. • y_LJL 


12/07 /99 


04 • 2Sn 


1 Q1 

-l Z? JL 


p_L C O . LjXl 


1 9 /07 /QQ 


0 4 • 9 Sn 

U T . Z. Op 


1 Q*^ 
± z) O 


p±tifi . g j_ x 


12/07/99 


04 • 9 Rn 

U *i • Z Op 


IRQ 


pie j . yn 


1 2 /07 /99 


04 ■ 9 Sn 
\j i . z. *jp 


J.OO 


piso . yll 


12/07/99 


04 - 2Sn 


IPS 
X o o 


pjLtr/ - y_LX 


19/07/99 


04 • 25o 


17"} 




1 2/07 /99 


04 * 25d 


254 

4. J T 


npirf ^ 1 rri "F 

yUl U. d J_ • y_LJ_ 


1 9 /(17/QQ 


04 • 2 Sn 


1 4 S8 


P 4- a /-^ +- -> n/~\m 3 i n 7\7 /~\ Ha ~i a TT3 

r IULcO L J_UrilJOIIla. OQS . J ci v a. 


i?/07/qq 


04 • 9 Sn 


9 4 4 

Z 4 4 


po . y 11 


1 2 /07 /QQ 


0 A • 9 Sn 

U *i . Z Op 


9 £7 
z, o / 


gum. . gir 


12/07/99 


0 4 • 2 Sn 


1 4^8 

1 ^ 4 JO 


r\cbUUiLeUcbClipLlOnL\Oa6 . j aVa 


19/07/QQ 
1Z / U / / 


0 A • 9 Sr^ 

u *± . z. op 


-L / Z. 


right . gif 




OA - 0 

U . £ Op 




KbUixiapNoae . j ava 


9 / 0 7 / Q Q 

^l Z. / U if Z> Z> 


04 • 9 Sn 


1 7 £ft 
x f / DO 




2/07 /QQ 


04 • 9 Sn 


9 S8 
z. o o 


oticwi . yii 


■ ^1 9 / 0 7 / Q Q 

X £~ / \J s f Z? Zs 


U *i > Z. JU 


9 £ *3 
Z. DO 


screwz • gii 


9 /D7 /QQ 


04 * 9 Sn 

U *i . Op 


9 A 9 
Z H Z. 


scrip u • gix 


■ M 2/07 /99 


04 • 9 Sn 


9 A 8 
Z. 4 O 


oOuiiQi . yii 


j ^19/07/QQ 

1 Z / \J f / z> z> 


04 • 9 Sn 

U *2 • £. Op 


Z.Z. X 


sounoz . gii 


^?/07/QQ 

: ■ 1 Z. I \J f / Z? Z? 


04 • 9 Sn 


9£ S 
z. o o 


spnerei . yii 


9 / 0 7 / Q Q 

X£ / \J / / Z? Zs 


04*9 Sn 
U 4 . Z. Op 


Z. D*i 


spnerez . gir 


; "19/07/QQ 

; X£. 1 \J \ 1 Z) Z) 


04 • 9 Sn 
u *i ■ z. op 


91 Q 

Z. ± z7 


ta i » gi f 


' |S "l 9 / 0 7 / Q Q 


04 • 9 Sn 

U . Z. Op 


9 S 1 
ZlO 1 


tsx . gif 


: Jl 9 / H 7 / Q Q 


0 4-9 Sn> 
u 4 . z. op 


9 9 Q 

z z. y 


lext . gi i 


9/07/99 


04 • 2Sn 


949 

Z. 4 Z. 


■j- y- z3 t~\ c? "F v rri "F 
Llailolci . Cjll 


-12/07/99 


04 • 2Sn 


9 1^4 

Z ^ O J4 


1 1 ccDl OW5 e 1 . J ava 


9/07 /99 


04 • 2 Sn 


9 d *3 S 
Z f 4 o o 


1 1 trtr^ei lr\eilQSl S! . J ava 


^12/07/99 


04 • 2 Sn 

U *1 • Z. p 


A 97 
O / ft z / 


1 1 eewoaer dCLory . j ava 


12/07/99 


04:25p 


8,315 


TreeResourcF^Vi s i t* o r i^VR 


12/07/99 


04:25p 


245 


unknown. gif 


12/07/99 


04:25p 


164 


up. gif 


12/07/99 


04:25p 


236 


uu. gif 


12/07/99 


04:25p 


236 


uuencoded. gif 


12/07/99 


04:25p 


228 


worldl . gif 


12/07/99 


04:25p 


261 


world2 . gif 



96 File(s) 71,673 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\contrib\browser\tree\C 
VS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
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12/16/99 06:18p 
12/16/99 06:18p 
12/16/99 06:18p 
12/16/99 06:18p 

6 File(s) 



test 

4,506 Entries 
48 Repository 
4 6 Root 
84 6 Template 
5,446 bytes 



Directory of E: \e~speak-src_991217\platf orm\ES\contrib\browser\ui 



12/0o/00 


fS A 

04 


: i3p 


<DIR> 




• 


12/06/00 


C\ A 

04 


: 33p 


<DIR> 




• • 


12/0 / / 99 


04 


: zop 




l,olo 


BrowserApp • j ava 


12/07/99 


04 


: 25p 




4, 628 


Browser Frame . j ava 


12/07/99 


04 


: 25p 




1 1 0 a 

1,780 


BrowserView . j ava 


12/07/99 


04 


: 25p 




2, 397 


BrowserToolBar . j ava 






: zop 




4 , ooy 


BrowserStatusBar . j ava 


12/07/99 


04 


:25p 




1,555 


BrowserMenuBar . j ava 


12/07/99 


04 


:25p 




5,285 


ConnectDlg . j ava 


12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/07/99 


04 


:25p 




2, 699 


FileMenu. java 


0.2/07/99 


04 


:25p 




2,842 


HelpMenu. java 


€2/07/99 


04 


:25p 




172 


left.gif 


12/07/99 


04 


:25p 




2, 081 


ListPane . j ava 


142/15/99 


04 


:00p 




861 


Makefile 


r l2/07/99 


04 


:25p 




3,291 


NumberField . j ava 


^2/07/99 


04 


:25p 




172 


right . gif 


12/07/99 


04 


:25p 




2,326 


TreePane . java 


■=12/07/99 


04 


:25p 




1,310 


Utility, java 


"12/07/99 


04 


:25p 




3,722 


ViewMenu. java 


•i;2/07/99 


04 


:25p 




1,388 


ViewTypes . j ava 



;| 21 File(s) 42,864 bytes 

^(Directory of E : \e-speak-src_991217\platf orm\ES\contrib\browser\ui\CVS 



^2/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06: 18p 
06:18p 

6 File(s) 



<DIR> 
<DIR> 



923 Entries 
4 6 Repository 
4 6 Root 

84 6 Template 
1,861 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\browser\util 



12/06/00 
12/06/00 
12/07/99 
12/06/00 
12/07/99 



04:33p 
04:33p 
04:25p 
04:33p 
04:25p 



<DIR> 
<DIR> 

<DIR> 



2,687 Application. java 
CVS 

8, 388 Def aultResourceVisitor . java 
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1 9 / 01 / QQ 




. Z Op 


S 97ft 

3 f Z / O 


£jX iiiai i\ebource . J dva 




04 


• 9 

. z op 


9 ££7 
Z r D D / 


r IdlueWOrKVOCaDUlaiy . J avd 


19/07 / QQ 


04 


• 9 Rn 


1 m 7 
1,31/ 


r rainewor KtiXcep Lion . j ava 


19 / 07 / QQ 

iz / u / / y y 


n a 


. Zop 


3 f lol 


Franiewor kContext . j ava 


iz / 10/ y y 


0 /l 


. uup 


0/0 


Makefile 


1 9 / n 7 / QQ 

i-c / u / / y y 


0/1 


. zop 


11 A t3 Q 
1 1 f 4 3 O 


PrintResourceVisitor . j ava 


1 9 /07 /QQ 


04 


■ 9 Sn 


2,484 


PrintTreeFactory . j ava 


12/07/99 


04 


:25p 


2,981 


ResourceVisitor . j ava 


12/07/99 


04 


:25p 


5, 682 


ResourceProvider . j ava 


12/07/99 


04 


:25p 


5,381 


ResourceDiscover . j ava 


12/07/99 


04 


:25p 


3,180 


VocabularyFinder . j ava 






16 File(s) 


55, 692 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\browser\util\C 
VS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

J2/16/99 06:18p 753 Entries 

% 2/16/99 06:18p 48 Repository 

'€2/16/99 06:18p 46 Root 

,^2/16/99 06:18p 846 Template 

% 6 File(s) 1,693 bytes 

if* 

^Directory of E:\e-speak-src_991217\platform\ES\contrib\CVS 

! I2/06/00 04:33p <DIR> 

fl2/06/00 04:33p <DIR> 

$2/16/99 06:18p 48 Entries 

$2/16/99 06:18p 63 Entries. Log 

$2/16/99 06:18p 35 Repository 

;3f2/16/99 06:18p 46 Root 

"$2/16/99 06:18p 846 Template 

^ 7 File(s) 1,038 bytes 



Directory of E:\e-speak-src_991217\platform\ES\contrib\gsysmon 



12/06/00 


04 


:33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/07/99 


04 


:25p 




5,116 BarSurf ace . java 


12/06/00 


04 


: 33p 


<DIR> 


CVS 


12/07/99 


04 


:25p 




1,806 Graphlntf . java 


12/07/99 


04 


:25p 




7,034 GraphSurf ace . java 


12/15/99 


04 


:00p 




533 Makefile 


12/07/99 


04 


:25p 




8,439 SysMonGui . j ava 


12/07/99 


04 


:25p 




7,198 TGFrame.java 






9 


File{s) 


30,126 bytes 
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test 

Directory of E: \e-speak-src_991217\platf orm\ES\contrib\gsysmon\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 305 Entries 

12/16/99 06:18p 43 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 1,240 bytes 



Directory of E:\e-speak — src 9912 17 \plat f orm\ES\contrib\sysinon 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:25p 386 Makefile 

12/07/99 04:25p 8,877 SysMon.java 

5 File(s) 9,263 bytes 

■^Directory of E: \e-speak-src_991217\platf orra\ES\contrib\sysmon\CVS 

l!2/06/00 04:33p <DIR> 
•12/06/00 04:33p <DIR> 

1:2/16/99 06:18p 96 Entries 

15/16/99 06:18p 42 Repository 

1 1^/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

:\ 6 File(s) 1, 030 bytes 

. directory of E:\e-speak-src_991217\platform\ES\contrib\vfs 

S/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

iti/06/00 04:33p <DIR> config 

12/06/00 04:33p <DIR> CVS 

12/06/00 04:33p <DIR> src 

5 File(s) 0 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\conf ig 



12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 






12/07/99 


04 


:25p 




20 


col 


12/07/99 


04 


:25p 




20 


co2 


12/06/00 


04 


:33p 


<DIR> 




CVS 


12/07/99 


04 


:25p 




2,895 


Makefile 


12/07/99 


04 


:25p 




1, 147 


Makefile .bat 


12/07/99 


04 


:25p 




135 


VFSBrowser . ini 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:25p 
04:25p 
04:25p 
04:25p 
04:25p 

13 File(s) 



test 

272 VFSBrowser.prop 
147 VFSFileStore.ini 
448 VFSFileStore.prop 
137 VFSShell.ini 
272 VFSShell.prop 
5,4 93 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\conf ig\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 



<DIR> 
<DIR> 



6 File(s] 



486 Entries 
46 Repository 
46 Root 

846 Template 
1,424 bytes 



Directory of E:\e-speak-src 991217\platf orra\ES\contrib\vf s\CVS 



012/06/00 
i2/06/00 
^2/16/99 
■£'2/16/99 
^2/16/99 
f 2/16/99 
! S2/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
06: 18p 

7 File(s) 



<DIR> 
<DIR> 



3 Entries 
29 Entries. Log 
39 Repository 
46 Root 
84 6 Template 
963 bytes 



^Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src 



S2/06/00 04:33p <DIR> 
jfe/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
¥2/06/00 04:33p <DIR> 
4 File(s) 



CVS 
vf s 
0 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
06:18p 

7 File(s) 



<DIR> 
<DIR> 



3 Entries 
13 Entries. Log 
43 Repository 
4 6 Root 
84 6 Template 
951 bytes 



Directory of E: \e-speak-src 991217\platform\ES\contrib\vf s\src\vf s 
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test 



12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 


browser 


12/06/00 


04 


:33p 


<DIR> 


clientapi 


12/06/00 


04 


: 33p 


<DIR> 


CVS 


12/06/00 


04 


: 33p 


<DIR> 


intf 


12/07/99 


04 


:25p 




450 Makefile 


12/06/00 


04 


: 33p 


<DIR> 


server 


12/06/00 


04 


: 33p 


<DIR> 


shell 


12/06/00 


04 


: 33p 


<DIR> 


util 






10 


File(s) 


450 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\br 



owser 












12/06/00 


04 


: 33p 


<DIR> 




• 


*! A f C\ f / A A 

12/06/00 


04 


A A 

: 33p 


<DIR> 




• • 


J.2/07/99 


04 


„ A IT 

: 2 op 




4, 924 


AttributeViewListener . j ava 


■|i z / u / / y y 


04 


: 2bp 




A 1 "7 A A 

31, 720 


AttributeView . j ava 


, -iz / u / / y y 


U 4 


: zop 




1 , 616 


Attributeltem. j ava 


, 12/07/99 


04 


: 25p 




25, 061 


Browser . j ava 


2 / 0 / / 9 9 


a /i 
04 


: 2 bp 




472 


Browser . resources 


^2/07/99 


04 


: 2op 




106, 734 


BrowsePane . j ava 


^12/07/99 


A A 

04 


: 25p 




4 , 296 


BrowsePane . resources 


:jt2/Q //99 


A A 

04 


: zop 




7, 855 


BrowseDialog . j ava 


12/07/99 


A 

04 


: 2 op 




11, 116 


CabinetAttributesDialog . j ava 


; X Z / UO / UU 




* ? "3lA 

. jop 








12/07/99 


04 


:25p 




2, 476 


DirectoryNode . j ava 


; : fc/07/99 


04 


:25p 




1, 614 


DragData. java 


: 2I2/07/99 


04 


: 25p 




6,742 


Filelnf o . java 


$2/07/99 


04 


:25p 




9,936 


FileStoreListDialog. java 


:3f2/07/99 


04 


:25p 




7, 950 


FolderWatcher . j ava 


1*2/06/00 


04 


: 33p 


<DIR> 




images 


12/07/99 


04 


:25p 




7,139 


Input Dialog. java 


12/07/99 


04 


:25p 




10,419 


LaunchFile . j ava 


12/07/99 


04 


:25p 




1, 120 


Makefile 


12/07/99 


04 


: 25p 




5, 151 


MessageBoxOnTop . j ava 


12/07/99 


04 


:25p 




15, 865 


NewFileDialog. java 


12/07/99 


04 


:25p 




10,893 


ProgressDialog . java 


12/07/99 


04 


:25p 




6,824 


PropertiesDialog. java 


12/07/99 


04 


: 25p 




41,781 


SearchPane . j ava 


12/07/99 


04 


:25p 




5,214 


SearchPane . resources 


12/07/99 


04 


:25p 




11,054 


SelectCabinetDialog . j ava 


12/07/99 


04 


:25p 




10,326 


SelectCabinetDialog . resources 


12/07/99 


04 


:25p 




3,472 


SplashScreen . j ava 


12/07/99 


04 


:25p 




235, 548 


SplashScreen . resources 


12/07/99 


04 


:25p 




1,805 


SysIiuageList . j ava 



Page 13 



12/07/99 04:25p 

33 File(s) 



test 

7,510 TreeWatcher . java 
597,633 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\br 
owser\CVS 



12/06/00 


04: 


33p 


<DIR> 






12/06/00 


04: 


33p 


<DIR> 






12/16/99 


06: 


18p 




1, 610 


Entries 


12/16/99 


06: 


18p 




16 


Entries . Log 


12/16/99 


06: 


18p 




55 


Repository 


12/16/99 


06: 


18p 




46 


Root 


12/16/99 


06: 


18p 




846 


Template 



7 File(s) 2,573 bytes 



Directory of E: \e-speak-src__991217\platf orm\ES\contrib\vf s\src\vf s\br 
owser\images 



J2/06/00 


04 


:33p 


<DIR> 






'■$2/06/00 


04 


: 33p 


<DIR> 






$2/06/00 


04 


: 33p 


<DIR> 




CVS 


,12/07/99 


04 


:25p 




9,484 


FILECOPY.AVI 


12/07/99 


04 


:25p 




1,238 


HPLogo . bmp 


:l2/07/99 


04 


:25p 




766 


LCabClose . ICO 


152/07/99 


04 


:25p 




766 


LCabOpen. ICO 


d'2/07/99 


04 


:25p 




766 


LFile. ICO 


12/07/99 


04 


:25p 




766 


LFLDClose. ICO 


12/07/99 


04 


:25p 




766 


LFLDOpen. ICO 


S2/07/99 


04 


:25p 




318 


SCabClose. ICO 


X2/07/99 


04 


:25p 




318 


SCabOpen. ICO 


3;2/07/99 


04 


:25p 




20,796 


SEARCH . AVI 


$2/07/99 


04 


:25p 




318 


SFile.ICO 


fe/07/99 


04 


:25p 




318 


SFLDClose.ICO 


&/07/99 


04 


:25p 




318 


SFLDOpen. ICO 



16 File(s) 36,938 bytes 



Directory of E: \e-speak-src_991217\platform\ES\contrib\vf s\src\vf s\br 
owser\images\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File (s; 



634 Entries 
62 Repository 
46 Root 

84 6 Template 
1,588 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\cl 
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ientapi 



test 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 

15 File(s) 



<DIR> 
<DIR> 
<DIR> 



CVS 

707 Makefile 
2, 021 NoFileStoreFoundException. java 
5,825 VFSFileStoreContract . java 

26,093 VFSFileCabinet. java 
8 , 312 VFSFileStoreVocabulary . j ava 

10,222 VFSFileStoreFinder. java 
1,969 VFSFileStoreElement . java 
4,040 VFSFileStoreDescription. java 

26,604 VFSFolder. java 

10, 343 VFSResourceVocabulary . java 
5,781 VFSResourceContract . java 

28,252 VFSWorkSpace. java 

130,169 bytes 



^{Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\cl 
/Ientapi \CVS 



^2/06/00 04:33p 



=J2/06/00 
32/16/99 
1^2/16/99 
12/16/99 
',12/16/99 



04:33p 
06:18p 
06:18p 
06:18p 
06:18p 

6 File(s) 



<DIR> 
<DIR> 



712 Entries 
57 Repository 
4 6 Root 
846 Template 
1, 661 bytes 



^Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\CV 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06: 18p 
06:18p 
06:18p 
06:18p 
7 



<DIR> 
<DIR> 



File (s) 



48 Entries 
95 Entries. Log 
47 Repository 
4 6 Root 
84 6 Template 
1,082 bytes 



^Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\in 



12/06/00 04:33p 
12/06/00 04:33p 
12/06/00 04:33p 



<DIR> 
<DIR> 
<DIR> 



CVS 
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test 



12/07/99 


04 


: 25p 


556 


Makefile 


12/07/99 


04 


: 25p 


5, 670 


VFSFilelntf iava 


12/07/99 


04 


:25p 




1, 849 


VFSFilelntfMessageRegistry . j ava 


12/07/99 


04 


:25p 


10,400 


VFSFileStub. java 


12/07/99 


04 


:25p 


8, 982 


VFSFileStoreStub. java 


12/07/99 


04 


:25p 


2,223 


VFSFileStorelntfMessageRegistry 


. java 










12/07/99 


04 


:25p 


4,145 


VFSFileStorelntf . java 






10 File(s) 


33,825 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\in 
tf\CVS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 411 Entries 

12/16/99 06:18p 52 Repository 

12/16/99 06:18p 46 Root 

JL2/16/99 06:18p 846 Template 

! t 6 File(s) 1,355 bytes 



IJfver 

$2/06/00 
5?2/06/00 

T2/06/00 04:33p <DIR> CVS 

[12/07/99 04:25p 9,327 DumpVFSEntries . j ava 

::i2/15/99 04:00p 542 Makefile 

11*2/07/99 04:25p 5,319 StartFileStore . j ava 

'12/07/99 04:25p 10,836 VFSFileStoreService. java 

J2/07/99 04:25p 25,820 VFSFileStorelmpl . j ava 

;i2/07/99 04:25p 13,228 VFSFilelmpl . java 
9 File(s) 65,072 bytes 



of E:\e- 


■speak-src 


04:33p 


<DIR> 


04:33p 


<DIR> 


04:33p 


<DIR> 


04:25p 




04:00p 




04:25p 




04:25p 




04:25p 




04 :25p 





Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\se 
rver\CVS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 332 Entries 

12/16/99 06:18p 54 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 1,278 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\sh 
ell 
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test 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
,12/07/99 
'112/07/99 
32/07/99 
32/07/99 
$2/07/99 
12/07/99 
!|2/07/99 
12/07/99 
.12/07/99 
12/07/99 
,12/07/99 



04:33p 
04:33p 
04:33p 
04:25p 
04 :25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04 :25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 

28 File(s) 



<DIR> 
<DIR> 
<DIR> 



967 
3,469 
3,830 

20, 179 

10,028 
3, 111 
7,278 
5,660 

12,226 
8,167 

10, 912 
5,754 
6,212 

14, 992 
2,901 
4,576 

10,724 
6,855 
5, 909 
5, 986 
1,776 

15,496 
7,593 
1,775 
3,280 

179, 656 



CVS 

Makefile 

VFScatCommand. java 
VFScdCommand . j ava 
VFSCommand . j ava 
VFScpCommand . j ava 
VFSechoCommand . j ava 
VFSexecCommand . j ava 
VFSexportCommand . j ava 
VFSf indCommand . j ava 
VFSimportCoramand . j ava 
VFS1 sCommand . j ava 
VFSmkdirCommand . j ava 
VFSmkf ileCommand. java 
VFSmvCommand . j ava 
VFSpwdComniand . j ava 
VFSre set Command . j ava 
VFSrmCommand . j ava 
VFSrmdirCommand . j ava 
VFSsetCommand. java 
VFSshareCommand. java 
VFSShellException . j ava 
VFSShell. java 
VFSshowCommand . j ava 
VFSStackException. java 
VFSStack. java 
bytes 



^Directory of E:\e-speak-src 991217\platf orm\ES\contrib\vf s\src\vf s\sh 
gllXCVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File(s) 



1,379 Entries 
53 Repository 
4 6 Root 
84 6 Template 
2,324 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\contrib\vf s\src\vf s\ut 
il 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> CVS 
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12/07/99 04:25p 
12/07/99 04:25p 

5 File(s) 



test 

401 Makefile 
3,4 69 VFSStrings. java 
3,870 bytes 



Directory of E : \e-speak-src_991217\platform\ES\contrib\vf s\src\vf s\ut 
il\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File(s) 



100 Entries 
52 Repository 
4 6 Root 
846 Template 
1,044 bytes 



Directory of E:\e-speak-src_991217\platform\ES\CVS 



12/06/00 
J2/06/00 
42/16/99 
/12/16/99 
,"12/16/99 
"52/16/99 
12/16/99 



04:33p 
04:33p 
06:17p 
06:22p 
06:17p 
06: 17p 
06: 17p 
7 



<DIR> 
<DIR> 



File (s) 



431 Entries 
110 Entries. Log 

27 Repository 

4 6 Root 
84 6 Template 
1,460 bytes 



| t ' Directory of E:\e-speak-src_991217\platform\ES\extern 



42/06/00 
I2/O6/OO 
$2/06/00 

12/06/00 
12/06/00 
12/06/00 



04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
6 



<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 



File (s) 



CVS 
ldap 
openxml 
oracle-lib 
0 bytes 



Directory of E:\e-speak-src_991217\platform\ES\extern\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
06:18p 
7 



<DIR> 
<DIR> 



File(s) 



3 Entries 
51 Entries. Log 
34 Repository 
4 6 Root 
84 6 Template 
980 bytes 



Directory of E:\e-speak-src_991217\platform\ES\extern\ldap 
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test 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> CVS 

12/08/99 01:52p 160,475 ldapjdk.jar 

4 File(s) 160,475 bytes 

Directory of E:\e-speak-src_991217\platform\ES\extern\ldap\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 51 Entries 

12/16/99 06:18p 39 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 982 bytes 

Directory of E:\e-speak-src_991217\platform\ES\extern\openxml 

12/06/00 04:33p <DIR> 
32/06/00 04:33p <DIR> \ 

J2/06/00 04:33p <DIR> CVS 

$2/08/99 01:49p 357,071 openxml.jar 

ij! 4 File(s) 357,071 bytes 

£ Directory of E: \e-speak-src_991217\platf orm\ES\extern\openxml\CVS 

22/06/00 04:33p <DIR> 

.'$2/06/00 04:33p <DIR> 

$2/16/99 06:18p 51 Entries 

|2/16/99 06:18p 42 Repository 

42/16/99 06:18p 46 Root 

|2/16/99 06:18p 846 Template 

6 File(s) 985 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\extern\oracle-lib 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> ]. 

12/08/99 01:57p 800,174 classeslll.zip 

12/06/00 04:33p <DIR> CVS 

4 File(s) 800,174 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\extern\oracle-lib\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:18p 54 Entries 
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test 

12/16/99 06:18p 45 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 991 bytes 



Directory of E:\e-speak-src_991217\platform\ES\samples 



12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/06/00 


04 :33p 


<DIR> 


CVS 


12/06/00 


04:33p 


<DIR> 


echo 


12/06/00 


04:33p 


<DIR> 


ESChat 


12/07/99 


04:25p 




290 Makefile 


12/06/00 


04:33p 


<DIR> 


ManagedEcho 


12/06/00 


04:33p 


<DIR> 


ManagedPrint Server 


12/06/00 


04:33p 


<DIR> 


PrintServer 




9 


File (s) 


290 bytes 



^Directory of E : \e-speak-src_9 912 17 \platform\ES\ samples \CVS 

$2/06/00 04:33p <DIR> 
JI2/06/00 04:33p <DIR> 

$2/16/99 06:18p 48 Entries 

$2/16/99 06:19p 100 Entries. Log 

;p/16/99 06:18p 35 Repository 

$2/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

7 File(s) 1,075 bytes 

directory of E:\e-speak-src_991217\platform\ES\samples\echo 

lfe/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

T2/06/00 04:33p <DIR> config 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:25p 4,998 echo.vjp 

12/07/99 04:25p 4,127 README . txt 

12/06/00 04:33p <DIR> src 

7 File(s) 9,125 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\echo\conf ig 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/07/99 04:25p 25 col.MYCO 

12/07/99 04:25p 26 co2.MYC0 

12/06/00 04:33p <DIR> CVS 

12/06/00 04:33p <DIR> multicore 
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12/06/00 04:33p <DIR> singlecore 

7 File(s) 51 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\samples\echo\conf ig\CV 

s 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 93 Entries 

12/16/99 06:19p 39 Entries. Log 

12/16/99 06:19p 47 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

7 File(s) 1,071 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\samples\echo\conf ig\mu 
ltxcore 

A2/06/00 04:33p <DIR> 
;iI2/06/00 04:33p <DIR> 

;|2/07/99 04:25p 64 client. prop 

,£2/06/00 04:33p <DIR> CVS 

12/07/99 04:25p 744 EchoClient.ini 

P/07/99 04:25p 730 EchoServer.ini 

;lj2/07/99 04:25p 42 server. prop 

|»t 7 File(s) 1,580 bytes 

I directory of E:\e-speak-src_991217\platform\ES\samples\echo\config\mu 

|2/06/00 04:33p <DIR> 
$2/06/00 04:33p <DIR> 

ft/16/99 06:19p 201 Entries 

12/16/99 06:19p 57 Repository 

12/16/99 06:19p 46 Ro £ t 

12/16/99 06:19p 846 Template 

6 File(s) 1,150 bytes 

Directory of E:\e-speak-src_991217\platform\ES\samples\echo\config\si 



60 client. prop 
CVS 

199 EchoClient.ini 
328 EchoServer.ini 
60 server. prop 
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nglecore 








12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


:33p 


<DIR> 


12/07/99 


04 


:25p 




12/06/00 


04 


: 33p 


<DIR> 


12/07/99 


04 


:25p 




12/07/99 


04 


: 25p 




12/07/99 


04 


:25p 





7 File(s) 



test 

647 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\samples\echo\conf ig\si 
nglecore\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File(s! 



201 Entries 
58 Repository 
46 Root 

846 Template 
1,151 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\echo\CVS 



12/06/00 
12/06/00 
12/16/99 
,42/16/99 
12/16/99 
$2/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 
06:19p 

7 File(s) 



<DIR> 
<DIR> 



95 Entries 
29 Entries. Log 
40 Repository 
4 6 Root 
846 Template 
1,056 bytes 



^Directory of E : \e-speak-src_991217\platf orm\ES\samples\echo\src 



.12/06/00 04:33p <DIR> 

i2/06/00 04:33p <DIR> 

•ft2/06/00 04:33p <DIR> 

=12/07/99 04:25p 

'52/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

java 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12/07/99 04:25p 

12 File(s) 



CVS 

5,216 EchoServer . java 

6,205 EchoClient . java 

2,397 EchoServicelntf .esidl 

3,838 EchoServiceStub. java 

1, 388 EchoServicelntfMessageRegistry . 

2,397 EchoServicelntf . java 
2,103 EchoServicelmpl. java 
22,016 echoUML.doc 
661 Makefile 
46,221 bytes 



Directory of E:\e-speak-src_991217\platform\ES\samples\echo\src\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04 :33p 
06:19p 
06:19p 
06:19p 



<DIR> 
<DIR> 



501 Entries 
44 Repository 
4 6 Root 
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12/16/99 06:19p 

6 File(s) 



test 

846 Template 
1,437 bytes 



Directory of E:\e-speak-src_991217\platform\ES\samples\ESChat 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> config 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:25p 3,550 README . txt 

12/06/00 04:33p <DIR> src 

6 File(s) 3,550 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\ESChat\conf 



12/06/00 
12/06/00 
12/06/00 
12/06/00 
12/06/00 



04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
5 



<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 



File{s) 



CVS 

multicore 
singlecore 
0 bytes 



^Directory of E : \e-speak-src_991217\platf orm\ES\samples\ESChat \conf : 

tys 



;fe/o6/oo 

12/06/00 
12/16/99 
:l2/16/99 
;fc/16/99 
&/16/ 9 9 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
06:18p 

7 File(s) 



<DIR> 
<DIR> 



3 Entries 
39 Entries. Log 
49 Repository 
4 6 Root 
846 Template 
983 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\ESChat \conf : 
multicore 



12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/07/99 


04 


:25p 




58 client. pr 


12/06/00 


04 


:33p 


<DIR> 


CVS 


12/07/99 


04 


: 25p 




757 ESChatServer.ini 


12/07/99 


04 


:25p 




164 ESChatClient.ini 


12/07/99 


04 


:25p 




57 0 ESChatAddCore.ini 


12/07/99 


04 


:25p 




58 server. pr 






8 


File(s) 


1,607 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\samples\ESChat \conf 
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multicore\CVS 



test 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File (s) 



255 Entries 
59 Repository 
4 6 Root 

84 6 Template 
1,206 bytes 



Directory of 
singlecore 



E: \e-speak-src_991217\platform\ES\samples\ESChat\conf ig\ 



12/06/00 
12/06/00 
12/07/99 
12/06/00 
12/07/99 
.12/07/99 
-12/07/99 



04:33p 
04:33p 
04:25p 
04:33p 
04:25p 
04:25p 
04:25p 



<DIR> 
<DIR> 

<DIR> 



7 File(s) 



57 client. pr 
CVS 

740 ESChatServer.ini 
204 ESChatClient.ini 
57 server. pr 
1,058 bytes 



if' Directory of E: \e-speak-src_991217\platf orm\ES\samples\ESChat\conf ig\ 
l.|finglecore\CVS 



I12/06/00 
.12/06/00 
".12/16/99 
.42/16/99 
.42/16/99 
S2/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06: 18p 
06:18p 
6 



<DIR> 
<DIR> 



File(s) 



201 Entries 
60 Repository 
4 6 Root 

84 6 Template 
1,153 bytes 



'Directory of E: \e-speak-src_991217\platf orm\ES\samples\ESChat\CVS 



12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:18p 

12/16/99 06:18p 

12/16/99 06:18p 

12/16/99 06:18p 

12/16/99 06:18p 

7 File(s) 



<DIR> 
<DIR> 



50 Entries 
29 Entries. Log 
42 Repository 
4 6 Root 
84 6 Template 
1,013 bytes 



Directory of E: \e-speak-src_991217\platform\ES\samples\ESChat\src 



12/06/00 
12/06/00 



04:33p 
04:33p 



<DIR> 
<DIR> 
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12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:25p 
04:33p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
9 



test 

3,4 66 ChatEventDist . java 
<DIR> CVS 

23,040 ESChatUML.doc 
9,527 ESChat.java 

404 Makefile 
3,219 MessageDialog. java 
3,185 Subscriber Impl. java 
File(s) 42,841 bytes 



Directory of E: \e-speak-src_991217\platform\ES\samples\ESChat\src\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06: 18p 
06:18p 
06:18p 
06: 18p 
6 



<DIR> 
<DIR> 



File(s) 



312 Entries 
46 Repository 
4 6 Root 

84 6 Template 
1,250 bytes 



gDirectory of E: \e-speak-src_991217\platf orm\ES\sam P les\ManagedEcho 



12/06/00 
12/06/00 
j l2/06/00 
!l2/06/00 
12/07/99 
12/06/00 



04:33p 
04:33p 
04:33p 
04:33p 
04:25p 
04:33p 
6 



<DIR> 
<DIR> 
<DIR> 
<DIR> 

<DIR> 



File(s) 



conf ig 
CVS 

2,236 README . txt 
src 
2,236 bytes 



gDirectory of E: \e-speak-src_991217\platf orm\ES\sam P les\ManagedEcho\co 



lf2/06/00 
■£2/06/00 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 



04 :33p 
04:33p 
04:25p 
04:25p 
04:33p 
04:25p 
04:25p 



<DIR> 
<DIR> 



<DIR> 



7 File(s) 



25 col.MYCO 
2 6 co2.MYCO 
CVS 

443 ManagedEcho.ini 
108 testMgr.ini 
602 bytes 



nSg\CVS ry ° f E:Xe " Speak ~ SrC - 991217X P latform \ ES \samples\ManagedEcho\co 



12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:18p 

12/16/99 06:18p 



<DIR> 
<DIR> 



193 Entries 
54 Repository 
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12/16/99 06:18p 
12/16/99 06:18p 

6 File(s) 



test 

4 6 Root 
84 6 Template 
1,139 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\saraples\ManagedEcho\CV 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
06:18p 
7 



<DIR> 
<DIR> 



File(s) 



50 Entries 
29 Entries. Log 
47 Repository 
46 Root 
846 Template 
1,018 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\ManagedEcho\sr 



j l2/06/00 04:33p <DIR> 

€2/06/00 04:33p <DIR> 

^2/06/00 04:33p <DIR> 

112/07/99 04:25p 

J2/07/99 04:25p 

;|2/07/99 04:25p 

!|ava 

'12/07/99 04:25p 

12/07/99 04:25p 

: l2/07/99 04:25p 

±2/07/99 04:25p 

S2/07/99 04:25p 

12/07/99 04:25p 
:S; 12 File(s) 



CVS 

2,212 EchoServicelntf . esidl 

2,343 EchoServiceStub. java 

1, 408 EchoServicelntfMessageRegistry . 

2,216 EchoServicelntf . java 
2,154 EchoServicelmpl . java 

688 Makefile 
6,077 ManagedEcho. java 
2,632 startManagedEcho . j ava 
4,196 testMgr.java 
23,926 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\ManagedEcho\sr 
c\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File (s) 



509 Entries 
51 Repository 
4 6 Root 

84 6 Template 
1,452 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\ManagedPrintSe 
rver 
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test 



12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 


conf ia 


12/06/00 


04 


:33p 


<DIR> 


CVS 


12/06/00 


04 


: 33p 


<DIR> 


doc 


12/09/99 


06 


:44a 




5,800 README . txt 


12/06/00 


04 


: 33p 


<DIR> 


SampleFiles 


12/06/00 


04 


: 33p 


<DIR> 


src 






8 


File (S) 


5,800 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\ManagedPrintSe 
rver\conf ig 



12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


:33p 


<DIR> 




12/06/00 


04 


:33p 


<DIR> 


CVS 


12/06/00 


04 


: 33p 


<DIR> 


multicore 


12/07/99 


04 


:25p 




380 Print.ini 


42/06/00 


04 


: 33p 


<DIR> 


singlecore 


ifii 




6 


File (s) 


380 bytes 



^Directory of E: \e-speak-src_991217\platform\ES\samples\ManagedPrintSe 

'i5fver\conf ig\CVS 



i5L2/06/00 
•£2/06/00 
;.12/16/99 
J2/16/99 
1^2/16/99 
>l : 2/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
06:18p 

7 File(s) 



<DIR> 
<DIR> 



49 Entries 
39 Entries. Log 
61 Repository 
46 Root 
846 Template 
1,041 bytes 



""'Directory of E: \e-speak-src_991217\platf orm\ES\ samples \ManagedPrintSe 
rver\conf igVnulticore 



12/06/00 


04:33p 


<DIR> 






12/06/00 


04:33p 


<DIR> 






12/07/99 


04:25p 




42 


Client .prop 


12/06/00 


04:33p 


<DIR> 




CVS 


12/07/99 


04:25p 




341 


PC.ini 


12/07/99 


04:25p 




538 


PC-Core. ini 


12/09/99 


07:02a 




1,696 


PS. ini 



7 File(s) 2,617 bytes 



Directory of E: \e-speak-src_991217\platform\ES\samples\ManagedPrintSe 
rver\conf ig\multicore\CVS 
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12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04 : 33p 
06: 18p 
06:18p 
06: 18p 
06:18p 
6 



<DIR> 
<DIR> 



File (s) 



test 



185 Entries 
71 Repository 
46 Root 

84 6 Template 
1,148 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\ManagedPrintSe 



rver\conf ig\singlecore 








12/06/00 


04:33p 


<DIR> 






12/06/00 


04:33p 


<DIR> 






12/07/99 


04 :25p 




42 Client 


• prop 


12/06/00 


04:33p 


<DIR> 


CVS 




12/07/99 


04:25p 




220 PC.ini 




12/07/99 


04:25p 




376 print.: 


ini 


12/09/99 


07:03a 




1,278 PS.ini 




12/07/99 


04:25p 




42 Server 


.prop 




8 File(s) 




1,958 bytes 





"^Directory of E: \e-speak-src_991217\platf orm\ES\samples\ManagedPrintSe 
;#ver\conf ig\singlecore\CVS 



452/06/00 
r S2/06/00 
r l2/16/99 
112/16/99 
•12/16/99 
j fc/16/99 



04:33p 
04:33p 
06: 18p 
06: 18p 
06: 18p 
06:18p 

6 File(s) 



<DIR> 
<DIR> 



231 Entries 
72 Repository 
46 Root 

846 Template 
1,195 bytes 



^Directory of E: \e-speak-src_991217\platf orm\ES\samples\ManagedPrintSe 



: rver\CVS 








12/06/00 


04: 


33p <DIR> 




12/06/00 


04: 


33p <DIR> 




12/16/99 


06: 


18p 


50 Entries 


12/16/99 


06: 


18p 


63 Entries. Log 


12/16/99 


06: 


18p 


54 Repository 


12/16/99 


06: 


18p 


4 6 Root 


12/16/99 


06: 


18p 


846 Template 






7 File(s) 


1,059 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\ samples \ManagedPrintSe 
rver\doc 



12/06/00 04:33p 



<DIR> 
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test 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/09/99 07:01a 96,647 Userguide.doc 

4 File(s) 96,647 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\samples\ManagedPrintSe 
rver\doc\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 53 Entries 

12/16/99 06:18p 58 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 1,003 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\samples\ManagedPrintSe 
rver\SampleFiles 

%2/06/00 04:33p <DIR> 

1*12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

:*l2/07/99 04:25p 181, 760 test. doc 

iL2/07/99 04:25p 351 test.ini 

:||2/07/99 04:25p 6 test.ppt 

;i2/07/99 04:25p 49 test.txt 

12/07/99 04:25p 6 test.xls 

1 8 File(s) 182, 172 bytes 

^Directory of E: \e-speak-src_991217\platform\ES\samples\ManagedPrintSe 

; 3tver\SampleFiles\CVS 

^2/06/00 04:33p <DIR> 

1*2/06/00 04:33p <DIR> 

12/16/99 06:18p 228 Entries 

12/16/99 06:18p 66 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File (s) 1, 186 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\samples\ManagedPrintSe 
rver\src 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/15/99 04:00p 799 Makefile 

12/07/99 04:25p 10,298 ManagedPrintService . java 



Page 29 





04 


• ?5r) 


12/07/99 


04 


: 25p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 


12/07/99 


04 


:25p 



12 File(s) 



test 

6,133 PolicyWriter. java 

18,611 PrintClient. java 

3,805 PrinterStub . java 

1,884 Printerlntf . java 

14,133 Printerlmpl . java 

5,539 Print Joblnfo. java 

18,441 PrintServer . java 

79, 643 bytes 



Directory of E: \e-speak-src_991217\platform\ES\samples\ManagedPrintSe 
rver\src\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06: 18p 
06:18p 

6 File(s] 



<DIR> 
<DIR> 



482 Entries 
58 Repository 
46 Root 

846 Template 
1,432 bytes 



*; Directory of E: \e-speak-src_991217\platf orm\ES\samples\PrintServer 



!ft2/06/00 


04 


:33p 


<DIR> 




: ; S2/06/00 


04 


:33p 


<DIR> 




^2/06/00 


04 


:33p 


<DIR> 


conf ig 


;l2/06/0C 


04 


:33p 


<DIR> 


CVS 


; 12/07/99 


04 


:25p 




4,4 99 README . txt 


f 12/06/00 


04 


: 33p 


<DIR> 


SampleFiles 


$2/06/00 


04 


:33p 


<DIR> 


src 






7 


File (s) 


4,499 bytes 


it= 

^Directory of E:' 


\e-speak-src_! 


991217\platform\ES\sampL 


r ; *|f ig 










12/06/00 


04 


:33p 


<DIR> 




12/06/00 


04 


:33p 


<DIR> 




12/06/00 


04 


:33p 


<DIR> 


col 


12/06/00 


04 


:33p 


<DIR> 


co2 


12/06/00 


04 


:33p 


<DIR> 


CVS 


12/06/00 


04 


:33p 


<DIR> 


multicore 


12/07/99 


04 


:25p 




297 Print.ini 


12/07/99 


04 


:25p 




1,973 printer. xml 


12/07/99 


04 


:25p 




1,688 printerl . xml 


12/07/99 


04 


:25p 




1,760 printit.pl 


12/07/99 


04 


:25p 




1,571 printVocab. xml 


12/06/00 


04 


: 33p 


<DIR> 


singlecore 






12 


File(s) 


7,289 bytes 
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test 

Directory of E : \e-speak-src_991217\platf orm\ES\samples\PrintServer\co 
nf ig\col 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:25p 25 col.MYCO 

12/06/00 04:33p <DIR> CVS 

4 File(s) 25 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\samples\PrintServer\co 
nfig\col\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 48 Entries 

12/16/99 06:18p 58 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

^ 6 File(s) 998 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\samples\PrintServer\co 
: ijf ig\co2 

% 2/06/00 04:33p <DIR> 

:j2/06/00 04:33p <DIR> 

^2/07/99 04:25p 25 co2.MYCO 

'12/06/00 04:33p <DIR> CVS 

;\, 4 File(s) 25 bytes 

^Directory of E: \e-speak-src_9 9 12 17 \platform\ES\samples\ Print Server \co 
:fffig\co2\CVS 

S2/06/00 04:33p <DIR> 

Tf2/06/00 04:33p <DIR> 

12/16/99 06:18p 48 Entries 

12/16/99 06:18p 58 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 998 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\samples\PrintServer\co 
nfig\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 244 Entries 

12/16/99 06:18p 65 Entries. Log 

12/16/99 06:18p 54 Repository 
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test 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

7 File(s) 1,255 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\PrintServer\co 
nf ig\multicore 



12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 






12/07/99 


04 


: 25p 




42 


Client .prop 


12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/07/99 


04 


: 25p 




202 


PC. ini 


12/07/99 


04 


:25p 




557 


PC-Core. ini 


12/07/99 


04 


:25p 




817 


PS. ini 






7 


File (s) 


1, 61* 


3 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\PrintServer\co 
nf ig\multicore\CVS 



! d2/06/00 
*i2/06/00 
,12/16/99 
512/16/99 
•.3.2/16/99 
£12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06: 18p 
06:18p 



<DIR> 
<DIR> 



6 File(s) 



185 Entries 
64 Repository 
4 6 Root 

846 Template 
1,141 bytes 



u Directory of E: \e-speak-src_991217\platf orm\ES\samples\PrintServer\co 
J=flf ig\singlecore 



12/06/00 04:33p <DIR> 

;i2/06/00 04:33p <DIR> 

12/07/99 04:25p 

12/06/00 04:33p <DIR> 

12/07/99 04:25p 

12/07/99 04:25p 

6 File(s) 



42 Client. prop 
CVS 
184 PC. ini 
426 PS. ini 

652 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\samples\PrintServer\co 
nf ig\singlecore\CVS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:18p 137 Entries 

12/16/99 06:18p 65 Repository 

12/16/99 06:18p 46 Root 

12/16/99 06:18p 846 Template 

6 File(s) 1,094 bytes 
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test 



Directory of E: \e-speak-src__991217\platform\ES\samples\PrintServer\CV 

S 



12/06/00 


04:33p <DIR> 




12/06/00 


04:33p <DIR> 




12/16/99 


06: 18p 


50 Entries 


12/16/99 


06:18p 


50 Entries. Log 


12/16/99 


06:18p 


47 Repository 


12/16/99 


06:18p 


4 6 Root 


12/16/99 


06: 18p 


84 6 Template 




7 File(s) 


1,039 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\PrintServer\Sa 
mpleFiles 



12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


:33p 


<DIR> 




..3.2/06/00 


04 


:33p 


<DIR> 


CVS 


''12/07/99 


04 


:25p 




181,760 test. doc 


:*12/07/99 


04 


:25p 




351 test.ini 


,'"12/07/99 


04 


:25p 




6 test.ppt 


;5l2/07/99 


04 


: 25p 




4 9 test.txt 


;4l2/07/99 


04 


:25p 




6 test.xls 






8 


File (s) 


182,172 bytes 



\ s Directory of E:\e-speak-src_991217\platform\ES\samples\PrintServer\Sa 

jjppleFiles\CVS 



: 12/06/00 
12/06/00 
42/16/99 
■12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:18p 
06:18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File (s) 



228 Entries 
59 Repository 
46 Root 

84 6 Template 
1,17 9 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\samples\PrintServer\sr 



12/06/00 


04 


:33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 






12/06/00 


04 


: 33p 


<DIR> 




CVS 


12/15/99 


04 


: OOp 




995 


Makefile 


12/07/99 


04 


:25p 




6, 152 


Print Server . j ava 


12/07/99 


04 


:25p 




16,750 


PrintClient . java 


12/07/99 


04 


: 25p 




2,375 


Print Joblnfo . esidl 


12/07/99 


04 


:25p 




2,524 


Print Joblnfo . j ava 
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12/07/99 

12/07/99 

12/07/99 

12/07/99 

. java 

12/07/99 

12/07/99 



04:25p 
04:25p 
04:25p 
04:25p 

04:25p 
04:25p 

14 File(s) 



test 

60,928 PrintServerUML.doc 

2,343 PrintServicelntf .esidl 

2,958 PrintServiceStub. java 

1, 574 PrintServicelntfMessageRegistry 

2,347 PrintServicelntf . java 

6,187 PrintServicelmpl. java 
105,133 bytes 



Directory of E:\e-speak-src_991217\platform\ES\samples\PrintServer\sr 
c\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06: 19p 
06: 18p 
06:18p 
06:18p 
6 



<DIR> 
<DIR> 



File (s) 



624 Entries 
51 Repository 
4 6 Root 
84 6 Template 
1, 567 bytes 



jj Directory of E:\e-speak-src_991217\platform\ES\src 



512/06/00 04:33p <DIR> 

;4fl2/06/00 04:33p <DIR> 

112/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

"12/06/00 04:33p <DIR> 

112/06/00 04:33p <DIR> 

^12/06/00 04:33p <DIR> 

«t 7 File(s) 



c 

CVS 
j ava 
perl 
python 
0 bytes 



g Directory of E:\e-speak-src_991217\platform\ES\src\c 

42/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
4 File(s) 



cesi 
CVS 
0 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\c\cesi 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 



04:33p 
04:33p 
04:25p 
04:25p 
04:25p 
04:25p 
04:33p 



<DIR> 
<DIR> 



<DIR> 



49,436 abi.c 
16,525 abi.h 
15,614 abi_base, 
4,223 abi_base 
CVS 
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test 



12/07 /99 


04 


: 25p 


19 , 827 




1? /07 /99 


04 


• ?5d 




p c ] i h h 


1 7 /07 /99 


04 


• zl. M 


620 


TTI ;3 V "F "1 1 


12/07 /99 


04 


: 25p 


631 


1 ILCJ. JvC J 1 L *3 Vv iLu 


12/07 /99 


04 


:25p 


408 


README txt 


12/07/99 


04 


: 25p 


3,716 


rtc. c 


12/07/99 


04 


:25p 


8, 036 


rts . c 


12/07/99 


04 


:25p 


3,745 


tc . c 


12/07/99 


04 


:25p 


5,654 


ts . c 


12/07/99 


04 


:25p 


13,071 


wservpipe . c 






17 File(s) 


145,01? 


3 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\c\cesi\CVS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:19p 624 Entries 

12/16/99 06:19p 38 Repository 

,12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

1 6 File(s) 1,554 bytes 



jfi Directory of E:\e-speak-src_991217\platforra\ES\src\c\CVS 

1^2/06/00 04:33p <DIR> 

j.2/06/00 04:33p <DIR> 

.12/16/99 06:19p 3 Entries 

',12/16/99 06:19p 14 Entries. Log 

•42/16/99 06:19p 33 Repository 

42/16/99 06: 19p 46 Root 

§2/16/99 06:19p 846 Template 

|l 7 File(s) 942 bytes 

""Directory of E:\e-speak-src_991217\platform\ES\src\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:19p 3 Entries 

12/16/99 06:22p 55 Entries. Log 

12/16/99 06:19p 31 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

7 File(s) 981 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
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12/06/00 04:33p <DIR> 
12/07/99 04:25p 
12/06/00 04:33p <DIR> 
5 File(s) 



test 

CVS 

187 Makefile 
net 
187 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06: 19p 
06:19p 
06:19p 
06:19p 
7 



<DIR> 
<DIR> 



File (s) 



48 Entries 
13 Entries. Log 
36 Repository 
4 6 Root 
84 6 Template 
989 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net 



,■42/06/00 04:33p <DIR> 

;|l2/06/00 04:33p <DIR> 

"12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 
ill 4 File(s) 



CVS 

espeak 
0 bytes 



fj| Directory of E:\e-speak-src_991217\platform\ES\src\java\net\CVS 



,12/06/00 
,,12/06/00 
1112/16/99 
'42/16/99 
tf.2/16/99 
#2/16/99 
$-2/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06: 19p 
06:19p 

7 File(s; 



<DIR> 
<DIR> 



3 Entries 
16 Entries. Log 
40 Repository 
4 6 Root 
84 6 Template 
951 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak 



12/06/00 


04 


:33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 


CVS 


12/06/00 


04 


: 33p 


<DIR> 


infra 


12/06/00 


04 


:33p 


<DIR> 


jesi 


12/07/99 


04 


:25p 




477 Makefile 


12/06/00 


04 


: 33p 


<DIR> 


services 


12/06/00 


04 


: 33p 


<DIR> 


util 


12/07/99 


04 


: 25p 




2,099 Version. j 


12/06/00 


04 


: 33p 


<DIR> 


webaccess 






10 File(s] 


1 


2,576 bytes 



Page 36 



test 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\CV 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:21p 
06:19p 
06:19p 
06:19p 
7 



<DIR> 
<DIR> 



File(s) 



97 Entries 
80 Entries. Log 
47 Repository 
4 6 Root 
84 6 Template 
1,116 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra 



cci 

client 

core 

CVS 

intercorecom 
269 Makefile 
xml 
269 bytes 



12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


,12/06/00 


04 


:33p 


<DIR> 


l|2/06/00 


04 


: 33p 


<DIR> 


=12/06/00 


04 


: 33p 


<DIR> 


,12/06/00 


04 


:33p 


<DIR> 


1512/06/00 


04 


: 33p 


<DIR> 


42/07/99 


04 


:25p 




^2/06/00 

•: U 


04 


:33p 


<DIR> 



9 File(s) 



M Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
r?f ra\cci 



:?L2/06/00 
$2/06/00 
12/06/00 
12/06/00 
12/06/00 
12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/06/00 
12/06/00 
12/06/00 
12/06/00 
12/06/00 



04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
04:25p 
04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
14 



<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 

<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 



File (s) 



coreapx 

coreproxy 

CVS 

events 
exception 
export 
357 Makefile 
management 
messaging 
metadata 
naming 
security 
357 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
fra\cci\coreapi 
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test 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
ava 

12/07/99 
12/07/99 
:-iL2/07/99 
&2/07/99 
:i2/07/99 



04:33p 
04:33p 
04:25p 
04:25p 
04:33p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
04:25p 

04:25p 
04:25p 
04:25p 
04:25p 
04:25p 
19 



<DIR> 
<DIR> 



<DIR> 



File(s; 



6,4 85 CoreManagement Interface . java 
8,572 CoreNames . java 
CVS 

8, 626 ImporterExporter Interface . j ava 
2,698 Keylnterf ace. java 
4,64 5 KeyRinglnterf ace . java 
5,388 Mailboxlnterf ace. java 

805 Makefile 
9,933 NameFramelnterf ace. java 
5, 301 Protect ionDomainlnterf ace. java 
6, 118 RepositoryViewInterf ace. java 
24,8 69 ResourceManipulationlnterf ace . j 

3, 754 ResourceFactorylnterface .java 
3,284 ResourceContract Interface. java 
4,752 SystemMonitorlnterface . j ava 
5, 108 VocabularyToolboxInterface .java 
4,922 Vocabularylnterf ace. java 
105,260 bytes 



j-jl Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
rff ra\cci\coreapi\CVS 



,12/06/00 
V12/06/00 
112/16/99 
ql2/16/99 
al.2/16/99 
-12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File (s) 



990 Entries 
65 Repository 
4 6 Root 

846 Template 
1,947 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\cci\coreproxy 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/06/00 
12/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:33p 
04:26p 



<DIR> 
<DIR> 



<DIR> 



6 File(s) 



6.240 ConnectionFactorylnterf ace. java 

4.241 CoreProxylnterf ace . java 
CVS 

400 Makefile 
10,881 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
f ra\cci\coreproxy\CVS 
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12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 

6 File(s) 



<DIR> 
<DIR> 



test 



176 Entries 
67 Repository 
46 Root 

846 Template 
1,135 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\cci\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06: 19p 
06:19p 
06:19p 
06: 19p 
06: 19p 

7 File(s) 



<DIR> 
<DIR> 



48 Entries 
178 Entries. Log 

57 Repository 

4 6 Root 
84 6 Template 
1,175 bytes 



?l Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
u f ra\cci\events 

•12/06/00 
1512/06/00 
32/07/99 

'12/06/00 04:33p <DIR> CVS 

i^.2/07/99 
§2/07/99 
;|2/07/99 
$2/07/99 



04:33p 


<DIR> 




04:33p 


<DIR> 




04:26p 




6,417 


04:33p 


<DIR> 




04:26p 




5,705 


04 :26p 




7,891 


04:26p 




14,456 


04:26p 




413 



8 File(s) 



34,882 bytes 



""Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\cci\events\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06: 19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File(s) 



256 Entries 
64 Repository 
4 6 Root 

84 6 Template 
1,212 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
f ra\cci\exception 



12/06/00 04:33p 



<DIR> 



Page 39 



12/06/00 


04 


: 33p 


12/07/99 


04 


:26p 


12/06/00 


04 


:33p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


,42/07/99 


04 


:26p 


;Ti2/07/99 


04 


:26p 


$2/07/99 


04 


:26p 


!><§va 






^2/07/99 


04 


: 2 6p 


i# . j ava 






:il2/07/99 


04: 


: 26p 


112/07/99 


04: 


:26p 


.12/07 /99 


04 • 


■ ?6r> 


a2/07/99 


04: 


:26p 


42/07/99 


04: 


:26p 


;42/07/99 


04: 


: 26p 


=12/07/99 


04 : 


:26p 


§2/07/99 


04: 


: 2 6p 


.=« 

12/07/99 


04 : 


:2 6p 


12/07/99 


04 : 


26p 


12/07/99 


04: 


2 6p 


va 






12/07/99 


04: 


2 6p 


12/07/99 


04: 


2 6p 


12/07/99 


04: 


2 6p 


va 






12/07/99 


04: 


26p 


12/07/99 


04 : 


26p 


12/07/99 


04: 


2 6p 


12/07/99 


04 : 


26p 


ava 






12/07/99 


04: 


26p 


java 







<DIR> 
<DIR> 



test 

2,419 CorePanicException. java 
CVS 

2,067 EmptyMappingExcept ion. java 
8,082 ESExceptionlnfo. java 
8,668 ESException. java 
2,404 ESInvocationException. java 
1,839 ESLibException. java 
2,356 ESNameFrameException. java 
2,375 ESRemoteExcept ion. java 
7,4 31 ESRuntimeExcept ion. java 
2,555 ESServiceException. java 
2,458 ExportFailedException. java 
2,458 ImportFailedExcept ion. java 
2,123 InvalidValueException. java 
2,092 InvalidTypeException. java 
4, 432 InvalidParameterException. java 
2,204 InvalidNameException. java 
2,158 LookupFailedExcept ion. java 
1,585 Makefile 

2, 454 MethodNotlmplementedException. j 

2,204 MultipleResolvedBindingExceptio 

2, 094 NameCollisionException. java 

2,064 NameNotFoundException. java 

2,14 3 NamingException. java 

2, 016 NotExportableExcept ion. java 

2, 022 Not ImportableException. java 

2, 152 NullParameterException. java 

2, 642 OutofOrderRequestException. java 

2. 117 PartialStateUpdateException. jav 

2, 119 PermissionDeniedException. java 
2, 066 QuotaExhaustedExcept ion. java 
2, 035 RecoverableDeliveryException. ja 

2, 274 RecoverableCoreException. java 
2, 088 RepositoryFullException. java 

2.118 RequestNotDeliveredException. ja 

2,453 ServicePanicException. java 

2, 164 StaleEntryAccessException. java 

2,112 TimedOutException. java 

2,332 UndeliverableRequestException . j 

2,216 UnrecoverableDeliveryException. 
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test 

12/07/99 04:26p 2,009 UnresolvedBindingException . j ava 

43 File(s) 107,600 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\cci\exception\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:19p 2,545 Entries 

12/16/99 06:19p 67 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 3,504 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\cci\export 

12/06/00 
,42/06/00 

!#l2/06/00 04:33p <DIR> CVS 

'$2/07/99 
,12/07/99 
12/07/99 
;|2/07/99 

!1| 7 File(s) 60,260 bytes 

], Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
\S ra \cci \export \CVS 

i|2/06/00 04:33p <DIR> 

312/06/00 04:33p <DIR> 

J2/16/99 06:19p 208 Entries 

42/16/99 06:19p 64 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,164 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
f ra\cci\management 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 368 Makefile 

12/07/99 04:26p 3,081 ManagedServiceOpcodes . java 

5 File(s) 3,449 bytes 



04:33p 


<DIR> 




04:33p 


<DIR> 




04:33p 


<DIR> 




04:26p 




15, 693 


04:26p 




27,068 


04:26p 




17,102 


04:26p 




397 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
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f ra\cci\management\CVS 



test 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:19p 111 Entries 

12/16/99 06:19p 68 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,071 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\cci\messaging 



i 9 /n fi /on 


D4 




<DTR> 






1Z/ UD/ uu 


Od 

U H 




NiJl i\/ 






1 9 /07 /QQ 
xz. / u / / y z> 




• 2 fin 




4 702 


duu to tia|jr\cjJiy • Java 


1 2 /07 /QQ 


OA 


• 9 fin 
> z, U 




17 4 Q2 


v^nai lilt: X w x X U *3 x • Java 


1 2 /07 /QQ 


D4 


• 2 fin 




21 2fil 


^iiciiiiiC J.i\caLiC j_ • Java 


12/07 /99 


04 


• 2 6n 




20 951 


Phsnnpl n p,vp. 

viiuiuicx > j u v a 


■ ; 2P 9 / D 7 / Q Q 


04 


- 9 fin 




12 2R0 


vyXiciiLUiiaiiiici • java 


>S$ 9 / n a / o n 


\J H. 


• ^ ?n 


\jjir\/ 






^9 /07 /QQ 


04 


• 2 fin 

• Z. U 




? 984 

-J , Z. O H 


JjOOcilalliaJJlc . J ava 


-¥2/07 /99 


04 


: 2 6p 




6, 155 


FTFOOueup i ava 

^_ _i— 1_ ^/ 1*4 * j {^4 V C_-4 


' ^? /07 /QQ 


04 


• 2 fin 

* z. w 




1 1 4RR 


T~n hnvMp c; c a rr o Z\ +~ pirn i ava 
X 1 iX-'kJ^vL It; ooay cnL vJiU •Java 


::12/07/99 


04 


: 2 6p 




9, 259 


I VMChannel . j ava 


;l?2/07/99 


04 


:26p 




7,410 


IVMQueue . j ava 


12/07/99 


04 


:26p 




2, 697 


IVMRendezvous . j ava 


"12/07/99 


04 


:26p 




962 


Makefile 


22/07/99 


04 


:2 6p 




7, 804 


Message . java 


1=312/07/99 


04 


:26p 




14,287 


MessageAtom. java 


!32/07/99 


04 


:26p 




34,717 


MessageRegistry . java 


fc/C7/99 


04 


:26p 




22,555 


MessageOutputStream. j ava 


312/07/99 


04 


:26p 




22, 914 


MessagelnputStream. j ava 


: l ? 2/07/99 


04 


:26p 




6, 647 


MessageBuf f eredStream. j ava 


12/07/99 


04 


:26p 




4,358 


MsgFilter . j ava 


12/07/99 


04 


:26p 




12, 195 


OutboxMessageAtom . j ava 


12/07/99 


04 


:26p 




4, 369 


PayloadRef erence . j ava 


12/07/99 


04 


:26p 




4, 380 


PayloadFromCore . j ava 


12/07/99 


04 


:26p 




3, 467 


PayloadForCore . j ava 


12/07/99 


04 


:26p 




3, 869 


Rendezvous . j ava 


12/07/99 


04 


:26p 




6, 153 


Resourcelnf 0 . j ava 


12/07/99 


04 


:26p 




3,800 


SystemMonitorHelper . j ava 


12/07/99 


04 


:26p 




12,380 


TCPChannel. java 


12/07/99 


04 


:26p 




3,229 


TCPRendezvous . j ava 



31 File(s) 289,067 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net \espeak\in 
f ra\cci\messaging\CVS 
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test 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04: 33p 
06:19p 
06:19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File(s) 



1,538 Entries 
67 Repository 
46 Root 
846 Template 
2,497 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\cci\metadata 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
J.2/07/99 
112/06/00 
*l2/07/99 
1.2/07/99 
il2/07/99 
;Jl2/07/99 
*i2/07/99 
1.2/07/99 
12/07/99 
: s 12/07/99 
42/07/99 
412/07/99 
$2/07/99 
32/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04 :26p 
04:26p 
04:26p 
04:26p 
04:26p 

20 File(s) 



<DIR> 
<DIR> 



<DIR> 



12,656 Attribute. java 
15,404 AttributeSet. java 

9,786 AttributePropertySet. java 
21,375 AttributeProperty. java 
10,960 AttributePredicate. java 
CVS 

29,182 ESUID.java 
704 Makefile 

1,756 Matcherlnterf ace. java 

3,7 60 NamedObject . java 

1,759 Promoter Interface. java 
31, 730 ResourceSpecif ication. java 

6,603 ResourceDescription. java 

8,575 RSD.java 
15,618 SearchRecipe . java 

6,406 SearchPredicate. java 
20,342 ValueType. java 
59,374 Value. java 
255,990 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
fra\cci\metadata\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File (s) 



929 Entries 
66 Repository 
4 6 Root 
84 6 Template 
1,887 bytes 



Directory of E : \e-speak-src_9912 17 \platf orm\ES\src\ j ava\net \espeak\in 
fra\cci\naming 
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test 



12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/07/99 


04 


: 26p 




3, 069 


12/06/00 


04 


: 33p 


<DIR> 




12/07/99 


04 


: 26p 




27,188 


12/07/99 


04 


:26p 




7,868 


12/07/99 


04 


:26p 




441 


12/07/99 


04 


:26p 




7,453 


12/07/99 


04 


:26p 




4,852 






9 


File(s) 


50, 87: 



CVS 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra \ cci \naming\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
,=,12/16/99 
!7i2/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 

6 File(sl 



<DIR> 
<DIR> 



316 Entries 
64 Repository 
46 Root 

84 6 Template 
1,272 bytes 



^ J Direct 
;=jf ra\cci 

:j2/06/0 
,12/06/0 
142/06/0 
42/07/9 
42/07/9 
$2/07/9 
12/07/9 



ory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
\security 



0 04:33p 

0 04:33p 

0 04:33p 

9 04:26p 

9 04:26p 

9 04:26p 

9 04:26p 

7 File(s] 



<DIR> 
<DIR> 
<DIR> 



CVS 

2,228 Lockable. java 

6,335 LockedPermissions . java 

4,131 Lock. java 

394 Makefile 
13,088 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\ 
fra\cci\ security \CVS 



m 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File (s) 



203 Entries 
66 Repository 
4 6 Root 
84 6 Template 
1,161 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
fra\client 
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test 



clientapi 
coreproxy 
corestubs 
CVS 

exception 
impl 
301 Makefile 
util 
301 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\client\clientapi 



12/06/00 


04 


:33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


:33p 


<DIR> 


12/06/00 


04 


:33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/07/99 


04 


:26p 




12/06/00 


04 


: 33p 


<DIR> 






10 


File (s) 



12/06/00 
12/06/00 
12/06/00 
,12/07/99 
13.2/07/99 

::i2/07/99 

,12/07/99 
^2/07/99 
42/07/99 
l;li2/07/99 
12/07/99 
12/07/99 
1J2/07/99 
:42/07/99 
42/07/99 
$2/07/99 
32/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 

18 File(s) 



<DIR> 
<DIR> 
<DIR> 



CVS 

2,613 ESContractlntf . java 

3,793 ESInboxIntf . java 

2,216 ESIntf.java 

3,218 ESKeylntf . java 

3,368 ESKeyRinglntf . java 
10,319 ESNameFramelntf . java 

3, 936 ESProtectionDomainlntf . java 

3,788 ESRemoteObjlntf . java 
13,674 ESRLIntf . java 

3,361 ESServicelntf . java 
40,793 ESShelllntf . java 

3,018 ESSystemMonitorlntf . java 

3,339 ESViewIntf . java 

3,267 ESVocabularylntf . java 
674 Makefile 
101,377 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\client\clientapi\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File(s) 



818 Entries 
70 Repository 
4 6 Root 
84 6 Template 
1,780 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
f ra\client\coreproxy 
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test 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04 :26p 
04:26p 
6 



<DIR> 
<DIR> 
<DIR> 



File (s) 



CVS 

33,299 ESConnectionFactory. java 
7,074 ESCoreProxy. java 

390 Makefile 
40,763 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
f ra\client\coreproxy\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File (s) 



162 Entries 
70 Repository 
4 6 Root 
84 6 Template 
1,124 bytes 



^Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
,£ra\client\corestubs 



; J.!2/06/00 
:j:2/06/00 
¥2/06/00 
12/07/99 
12/07/99 
!j2/07/99 
42/07/99 
•3f2/07/99 
:fe/07/99 
tt2/07/99 
T2/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04 :2 6p 
04 :2 6p 
04:26p 
2 6p 
26p 
26p 
26p 
2 6p 



<DIR> 
<DIR> 
<DIR> 



04 
04 
04 
04 
04 



04:2 6p 
17 



File(s) 



CVS 

12,959 ImporterExporter . java 
8,599 InterfaceToCore. java 
5,527 KeyRing.java 
3,281 Key. java 
7,38 6 Mailbox. java 
642 Makefile 

17,94 5 Name Frame. java 
6,081 ProtectionDomain. java 
9,201 RepositoryView. java 

42,410 ResourceManipulation. java 
4,920 ResourceFactory. java 
3,469 ResourceContract. java 
5,250 SystemMonitor. java 
5,396 Vocabulary . java 

133,066 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\client\corestubs\CVS 



12/06/00 04:33p 
12/06/00 04:33p 
12/16/99 06:19p 



<DIR> 
<DIR> 



755 Entries 
Page 4 6 



test 

12/16/99 06:19p 70 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,717 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\client\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 48 Entries 

12/16/99 06:19p 104 Entries. Log 

12/16/99 06:19p 60 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

7 File(s) 1,104 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
.«f ra\client\exception 

£{2/06/00 04:33p <DIR> 
;j2/06/00 04:33p <DIR> 

it|2/07/99 04:26p 2,505 CoreNotFoundException. iava 

42/06/00 04:33p <DIR> CVS 

if 2/07/99 04:26p 409 Makefile 

42/07/99 04:26p 2,937 UnexpectedExceptionException. ja 

,va 

M 6 File(s) 5,851 bytes 

^Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
rf ra\client\exception\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 181 Entries 

12/16/99 06:19p 70 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,143 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
fra\client\impl 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 5,506 ESContract . java 

12/07/99 04:26p 9,352 ESCoreManagementService . j ava 
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test 


12/07/99 


04:26p 


17, 920 


12/07/99 


04:26p 


8,421 


12/07/99 


04:2 6p 


7,753 


12/07/99 


04:26p 


4,747 


12/07/99 


04:26p 


17,440 


va 






12/07/99 


04:26p 


23,204 


12/07/99 


04:26p 


8,391 


12/07/99 


04:26p 


10,068 


12/07/99 


04:26p 


36,740 


12/07/99 


04 :26p 


3,837 


12/07/99 


04:26p 


112, 191 


12/07/99 


04:26p 


6,037 


12/07/99 


04:26p 


13,322 


12/07/99 


04:26p 


9,792 


12/07/99 


04:26p 


8,090 


12/07/99 


04:26p 


738 


12/07/99 


04:26p 


16, 647 




22 File(s) 


320, 19' 



ESImporterExporter . j ava 
ESInbox. java 
ESKeyRing . j ava 
ESKey. java 

ESManagedCoreManagedResource . 



-5 Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\ 
;Jra\client\impl\CVS 



;|2/06/00 
$2/06/00 
IJ2/16/99 
',12/16/99 
U12/16/99 
112/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File(s) 



1,011 Entries 
65 Repository 
4 6 Root 
84 6 Template 
1,968 bytes 



^Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\ 
'i ra\client\util 



12/06/00 


04 


:33p 


<DIR> 








12/06/00 


04 


:33p 


<DIR> 








12/07/99 


04 


:26p 




10, 


093 


CoreNameList , j ava 


12/06/00 


04 


: 33p 


<DIR> 






CVS 


12/07/99 


04 


: 2 6p 




4, 


571 


ESPOPInfo. java 


12/07/99 


04 


:2 6p 




2, 


699 


ExtractException . j ava 


12/07/99 


04 


: 26p 




4, 


557 


HelperMethods .java 


12/07/99 


04 


:26p 






635 


Ma kef ile 


12/07/99 


04 


:26p 




12, 


720 


MessageState .java 


12/07/99 


04 


:26p 




16, 


524 


MessageHandler . java 


12/07/99 


04 


:26p 




11, 


781 


MethodPermissionMap . j ava 


12/07/99 


04 


:26p 




5, 


547 


MsgldentityFilter . java 


12/07/99 


04 


:26p 




5, 


919 


MsgRSDFilter . j ava 


12/07/99 


04 


:26p 




4, 


811 


ParameterLis t . j ava 
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12/07/99 
12/07/99 
12/07/99 



04:26p 
04:26p 
04:26p 

17 File(s) 



test 

5,598 ParamUnit . java 
2,340 Trace. java 
5,560 Userlnf o . j ava 
93,355 bytes 



Directory of E: \e-speak-src_9 91217 \platform\ES\src\java\net\espeak\i 
fra\client\util\CVS 



in 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 



<DIR> 
<DIR> 



6 File(s) 



753 Entries 
65 Repository 
4 6 Root 

846 Template 
1,710 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\core 



.U.2/06/00 
0.2/06/00 
,42/06/00 
;42/06/00 
;|2/06/00 
;il2/06/00 
12/06/00 
142/07/99 
,42/06/00 
42/06/00 
42/06/00 
12/06/00 
42/06/00 
12/06/00 
12/06/00 
12/06/00 
12/06/00 
12/06/00 
12/06/00 
12/06/00 
12/06/00 



04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
04:40p 
04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
04:33p 
21 



<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 

<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 



File(s) 



contract 
CVS 

exception 
export 
mailbox 
443 Makefile 
management 
naming 
pd 

plugins 
quota 

repository 

resource 

router 

security 

startup 

sysmon 

util 

vocabulary 
4 43 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\ 
fra\core\contract 



m 



12/06/00 04:33p 
12/06/00 04:33p 
12/07/99 04:40p 



<DIR> 
<DIR> 



12,648 Contract .java 
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12/06/00 
12/07/99 
12/07/99 



04:33p 
04:40p 
04:40p 

6 File(s) 



test 

<DIR> CVS 

375 Makefile 
2,666 RegistrylF. java 
15, 689 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\core\contract\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File(s) 



150 Entries 
67 Repository 
4 6 Root 
84 6 Template 
1,109 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\core\CVS 



112/06/00 
"12/06/00 
1.12/16/99 
$.2/16/99 

ifl2/16/99 
iil2/16/99 
13.2/16/99 



04:33p 
04:33p 
06:19p 
06:20p 
06:19p 
06:19p 
06:19p 

7 File(s) 



<DIR> 
<DIR> 



48 Entries 
289 Entries. Log 

58 Repository 

4 6 Root 
84 6 Template 
1,287 bytes 



|-|| Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
ijf ra\core\exception 



=12/06/00 04:33p <DIR> 
§2/06/00 04:33p <DIR> 

12/07/99 04:40p 

12/06/00 04:33p <DIR> 

12/07/99 04:40p 

5 File(s) 



2, 531 AssertionFailedException. java 
CVS 

372 Makefile 
2,903 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
fra\core\exception\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File(s) 



114 Entries 
68 Repository 
4 6 Root 
84 6 Template 
1,074 bytes 
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test 



fra\core\export 




i 9 /ri6 /no 


u 4 • oop 


<DIR> 


-L Z. / U 0 / UU 




<DIR> 


12/06/00 


04:33p 


<DIR> 


12/07/99 


04:40p 




12/07/99 


04:40p 




12/07/99 


04:40p 




12/07/99 


04:40p 




12/07/99 


04:40p 




12/07/99 


04: 40p 




12/07/99 


04:40p 






10 File(s) 





5, 999 
42,803 

8,112 
19, 363 
26,949 
55,249 
485 

158, 960 bytes 



CVS 

ExportMessagelnputStream. java 
Exporter. java 
FrameMapEntry . j ava 
ImportExportNames . j ava 
ImporterExporter . j ava 
Importer . java 
Makefile 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\core\export\CVS 



33.2/06/00 
J12/06/00 
3.2/16/99 
SJ2/16/99 
$2/16/99 
512/16/99 



04:33p 
04:33p 
06:19p 
06:19p 
06:19p 
06:19p 

6 File(s) 



<DIR> 
<DIR> 



386 Entries 
65 Repository 
4 6 Root 
84 6 Template 
1,343 bytes 



^Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
-rf ra\core\mailbox 



,=§2/06/00 04:33p <DIR> 

J2/06/00 04:33p <DIR> 

42/07/99 04:40p 

12/07/99 04:40p 

12/07/99 04:40p 

12/07/99 04:40p 

12/06/00 04:33p <DIR> 

12/07/99 04:40p 

12/07/99 04:40p 

12/07/99 04:40p 

12/07/99 04:40p 

12/07/99 04:40p 

12 File(s) 



6,974 ChannelWriterThread. java 
2, 655 ChannelWriterDaemon . j ava 
6,985 ChannelThreadPool. java 
4,675 CoreChannel . java 
CVS 

10,995 Inbox. java 
527 Makefile 
2,344 MessageQueueltem. java 
5,321 MessageQueue . java 

10,818 Outbox.java 
51,294 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
fra\core\mailbox\CVS 



12/06/00 04:33p 



<DIR> 
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12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
06: 19p 
06: 19p 
06:19p 
06:19p 
6 



<DIR> 



File(s) 



test 

489 Entries 
66 Repository 
46 Root 

846 Template 
1,447 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
f ra\core\management 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04 : 40p 
04 : 40p 



<DIR> 
<DIR> 
<DIR> 



5 File(s) 



CVS 

372 Makefile 
16, 612 ManagedAbstractResource . java 
16,984 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
4ra\core\management\CVS 



-32/06/00 
,12/06/00 
■12/16/99 
12/16/99 
S2/16/99 
,12/16/99 



04:33p 
04:33p 
06:19p 
06: 19p 
06:19p 
06:19p 
6 



<DIR> 
<DIR> 



File(s) 



113 Entries 
69 Repository 
4 6 Root 

84 6 Template 
1,074 bytes 



ilpirectory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
i3ra\core\naming 



il2/06/00 
52/06/00 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:40p 
04:33p 
04:40p 
04:40p 
04 : 40p 
04:40p 
04:40p 
9 



<DIR> 
<DIR> 

<DIR> 



File(s) 



5,107 Binding. java 
CVS 

454 Makefile 
23,229 MappingObject . java 
94,368 Name Frame. java 

8,209 NameSearchPolicyMatcher . java 

6,580 PartialBinding. java 
137,947 bytes 



Directory of E : \e-speak-src_991217 \platf orm\ES\src\ j ava\net \espeak\in 
f ra\core\naming\CVS 



12/06/00 04:33p 
12/06/00 04:33p 
12/16/99 06:19p 



<DIR> 
<DIR> 



324 Entries 
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12/16/99 
12/16/99 
12/16/99 



06:19p 
06:19p 
06:19p 
6 



File (s) 



test 

65 Repository 
46 Root 
84 6 Template 
1,281 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
f ra\core\pd 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:40p 
04:40p 
04:40p 
6 



<DIR> 
<DIR> 
<DIR> 



File(s; 



CVS 

377 Makefile 
30,042 ProtectionDomain. java 
5,997 WorkingSet . java 
36,416 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\core\pd\CVS 



11.2/06/00 
:*i2/06/00 
,42/16/99 
512/16/99 
412/16/99 
'#2/16/99 



04:33p 
04:33p 
06:19p 
06: 19p 
0 6 : 1 9p 
06:19p 
6 



<DIR> 
<DIR> 



File (s; 



158 Entries 
61 Repository 
4 6 Root 

846 Template 
1,111 bytes 



^Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
jff ra\core\plugins 



12/06/00 
-12/06/OC 
i2/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
12/06/00 



04:33p 
04:33p 
04:33p 
04:40p 
04:40p 
04:40p 
04:40p 
04:33p 
04:33p 



<DIR> 
<DIR> 
<DIR> 



<DIR> 
<DIR> 



9 File(s) 



CVS 

393 Makefile 
3,4 95 PluglnLoader . j ava 
1,776 PluglnlF. java 
4,548 Plugln.java 

secureboot 

testplugin 
10,212 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
f ra\core\plugins\CVS 



12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:19p 

12/16/99 06:19p 



<DIR> 
<DIR> 



200 Entries 
40 Entries. Log 
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test 

12/16/99 06:19p 66 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

7 File(s) 1,198 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\core\plugins\secureboot 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> CVS 

12/07/99 04:40p 4,395 SecureBoot . j ava 

4 File(s) 4,395 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\core\plugins\secureboot\CVS 



12/06/00 


04: 


33p 


-12/06/00 


04: 


33p 


,112/16/99 


06: 


19p 


UL2/16/99 


06: 


19p 


UfL2/16/99 


06: 


19p 


112/16/99 


06: 


19p 






6 



<DIR> 
<DIR> 

55 Entries 
77 Repository 
4 6 Root 
846 Template 
File(s) 1,024 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\core\plugins\testplugin 

1H2/06/00 04:33p <DIR> 

:i2/06/00 04:33p <DIR> 

112/06/00 04:33p <DIR> CVS 

$.2/07/99 04:41p 1,915 TestPlugln . j ava 

3 4 File(s) 1,915 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
f ra\core\plugins\testplugin\CVS 



12/06/00 


04:33p 


<DIR> 






12/06/00 


04:33p 


<DIR> 






12/16/99 


06:19p 




55 


Entries 


12/16/99 


06:19p 




77 


Repository 


12/16/99 


06:19p 




46 


Root 


12/16/99 


06:19p 




846 


Template 



6 File(s) 1,024 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\core\quota 
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12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:41p 
04 :41p 
04 :41p 
04:41p 

7 File(s) 



<DIR> 
<DIR> 
<DIR> 



test 



CVS 

389 Makefile 
10,189 QuotaCheck. java 
14,951 QuotaSize. java 
25,082 Quota. java 
50,611 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
f ra\core\quota\CVS 



12/06/00 


04:33p 


<DIR> 


12/06/00 


04:33p 


<DIR> 


12/16/99 


06:19p 




12/16/99 


06:19p 




12/16/99 


06:19p 




12/16/99 


06:19p 






6 


File (s) 


\] Directory of E:\e-speak-src 


UjEra\core\repository 


312/06/00 


04:33p 


<DIR> 


1112/06/00 


04:33p 


<DIR> 


WL2/07/99 


04:41p 




,12/07/99 


04:41p 




•,42/07/99 


04:41p 




1112/07/99 


04:41p 




£12/07/99 


04:41p 




.112/06/00 


04:33p 


<DIR> 


3.2/07/99 


04:41p 




iS.2/06/00 


04:33p 


<DIR> 


12/07/99 


04:41p 




12/06/00 


04:33p 


<DIR> 


12/07/99 


04:41p 




12/07/99 


04:41p 




12/07/99 


04:41p 




12/07/99 


04:41p 




12/07/99 


04:41p 




12/07/99 


04:41p 




12/07/99 


04:41p 




12/07/99 


04:41p 






20 


File(s) 



198 Entries 
64 Repository 
4 6 Root 
84 6 Template 
1,154 bytes 



14,917 AbstractStore. java 

7,254 ActiveResourceOwners . java 
14,960 CacheEntry . java 
10,740 CacheStats. java 
30,996 Cache. java 
CVS 

15, 703 DumpCor e . j a va 
jdbc 
771 Makefile 
mem 

17,870 RepositoryView. java 

4,437 RepositoryReset . java 
24,681 RepositoryHandle. java 
30,283 Repository . java 
2 9,593 Scavenger . j ava 
3,452 StoreUnitsIF. java 
8,091 StoreUnitList. java 
4,335 StoreUnit . java 
218,083 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
f ra\core\repository\CVS 
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test 


12/06/00 


04:33p <DIR> 




12/06/00 


04:33p <DIR> 




12/16/99 


06:19p 


800 Entries 


12/16/99 


06:20p 


27 Entries. Log 


12/16/99 


06:19p 


69 Repository 


12/16/99 


06:19p 


4 6 Root 


12/16/99 


06: 19p 


846 Template 




7 File(s) 


1,788 bytes 



Directory of E : \e-speak-src__991217\platf orm\ES\src\ j ava\net \espeak\in 
f ra\core\repository\ jdbc 



12/06/00 


04: 


33p 


<DIR> 






12/06/00 


04: 


33p 


<DIR> 






12/06/00 


04: 


33p 


<DIR> 




CVS 


12/07/99 


04: 


41p 




14,197 


JDBCRepositoryHandle . j ava 


12/07/99 


04: 


41p 




29,056 


JDBCHouseKeeping . j ava 


12/07/99 


04: 


41p 




31,040 


JDBCResourceState . java 


r*il2/07/99 


04: 


41p 




13, 912 


JDBCResourceSpecif ication. java 


!mL2/07/99 


04: 


41p 




10,243 


JDBCResourceLookup . j ava 


CjL2/07/99 


04: 


41p 




22,361 


JDBCResourceDescription. java 


i 12/07/99 


04: 


41p 




17, 317 


JDBCSqlStrings . j ava 


1112/07/99 


04: 


41p 




16,847 


JDBCStore. java 


42/07/99 


04: 


41p 




576 


Makefile 






12 


File (s) 


155,549 bytes 



is" Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
y£. ra\core\repository\jdbc\CVS 

;;ffL2/06/00 04:33p <DIR> 
i|il2/06/00 04:33p <DIR> 

01.2/16/99 06:20p 526 Entries 

S2/16/99 06:19p 74 Repository 

12/16/99 06:19p 46 Root 

12/16/99 06:19p 846 Template 

6 File(s) 1,492 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
f ra\core\repository\mem 



12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 


CVS 


12/07/99 


04 


:41p 




381 Makefile 


12/07/99 


04 


:41p 




7,591 MemStoreDB. java 


12/07/99 


04 


:41p 




14,7 77 MemSt ore. java 






6 


File(s) 


22,749 bytes 
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test 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\core\ repository \mem\CVS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:20p 150 Entries 

12/16/99 06:20p 73 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

6 File(s) 1,115 bytes 



fra\core\ resource 


12/06/00 


04 


:33p 


12/06/00 


04 


: 33p 


12/07/99 


04 


:41p 


12/07/99 


04 


:41p 


,42/06/00 


04 


:33p 


; 'l2/07/99 
512/07/99 


04 


:41p 


04 


:41p 


J2/07/99 


04 


:41p 


12/07/99 


04 


:41p 


•€2/07/99 


04 


:41p 


$2/07/99 


04 


:41p 


,12/07/99 


04 


:41p 


L12/07/99 


04 


:41p 



<DIR> 
<DIR> 

18,587 AbstractResource . java 
23, 240 CoreManagementService. java 
<DIR> CVS 

15,970 ESUIDFactory. java 
6,218 ExternalResource. java 
576 Makefile 
59,946 MetaResource . java 

2,800 MutableResourcelF. java 
14,087 ResourceType . java 
12, 611 ResourceSpecif ication. java 
17,749 ResourceFactory . java 
h* 13 File(s) 171,784 bytes 

lis \ 

^Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
Of ra\core\resource\CVS 

32/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:20p 568 Entries 

12/16/99 06:20p 67 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

6 File(s) 1,527 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
fra\core\r outer 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:41p 369 Makefile 

12/07/99 04:41p 2,282 Response . j ava 
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12/07/99 04:41p 

6 File(s) 



test 

17,0 60 Router. java 
19,711 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
f ra\core\ router \CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File (s! 



146 Entries 
65 Repository 
46 Root 

84 6 Template 
1,103 bytes 



Directory of E: \e-speak-src_991217\platf orra\ES\src\java\net\espeak\in 
fra\core\ security 



12/06/00 


04 


: 33p 


<DIR> 






,=42/06/00 


04 


: 33p 


<DIR> 






712/06/00 


04 


: 33p 


<DIR> 




CVS 


"12/07/99 


04 


: 41p 




1, 824 


KeylF. java 


i!2/07/99 


04 


:41p 




10,631 


KeyRing. java 


112/07/99 


04 


:41p 




7,550 


Key. java 


iJi2/07/99 


04 


: 41p 




456 


Makefile 


1112/07/99 


04 


:41p 




24,731 


MD5 .java 


,=0.2/07/99 


04 


: 41p 




9, 913 


SecurityContext Factory 


» 12/07/99 


04 


:41p 




3,095 


SecurityContext . j ava 



10 File(s) 



58,200 bytes 



3 Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
!£ra\core\security\CVS 



'12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File (s) 



355 Entries 
67 Repository 
4 6 Root 
846 Template 
1,314 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\core\ startup 



12/06/00 
12/06/00 
12/07/99 
12/06/00 
12/07/99 



04:33p 
04:33p 
04:41p 
04:33p 
04:41p 



<DIR> 
<DIR> 

<DIR> 



12,653 CoreArgs . j ava 
CVS 

414 Makefile 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:41p 
04:41p 
04:41p 
04:41p 
9 



File (s) 



test 

2,166 pingServer . real 
5,724 Server. java 
6,003 StartESCore. java 
35,87 6 StartupCore . java 
62,836 bytes 



Directory of E:\e-speak-src 991217\platform\ES\src\ j ava\net \espeak\in 
f ra\core\startup\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 

6 File(s) 



<DIR> 
<DIR> 



304 Entries 
66 Repository 
46 Root 

846 Template 
1,262 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
ijf ra\core\sysmon 



712/06/00 04:33p 
,12/06/00 
112/06/00 
•■$.2/07/99 

;il2/07/99 



04:33p 
04:33p 
04:41p 
04:41p 

5 File(s) 



<DIR> 
<DIR> 
<DIR> 



CVS 

357 Makefile 
8,817 SystemMonitor . java 
9,174 bytes 



*ii Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net \espeak\in 
~|f ra\core\sysmon\CVS 



112/06/00 
=12/06/00 
3.2/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File (si 



103 Entries 
65 Repository 
4 6 Root 

846 Template 
1,060 bytes 



f ra\core\util 






12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/07/99 


04:41p 




24, 650 


12/06/00 


04:33p 


<DIR> 




12/07/99 


04:41p 




35,464 


12/07/99 


04:41p 




395 


12/07/99 


04:41p 




7,463 



CVS 
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7 File(s) 



test 

67,972 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\core\util\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:20p 205 Entries 

12/16/99 06:20p 63 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

6 File(s) 1,160 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\core\ vocabulary 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

42/06/00 04:33p <DIR> CVS 

12/07/99 04:41p 24,331 Expression . j ava 

&2/07/99 04:41p 3,717 ExprNode . j ava 

,12/07/99 04:41p 9,836 LiteralNode. java 

$2/07/99 04:41p 480 Makefile 

.,12/07/99 04:41p 19,310 OpNode.java 

,§2/07/99 04:41p 5,454 PropertyNode . j ava 

•J2/07/99 04:41p 17,130 Tokenizer . java 

,,12/07/99 04:41p 16, 969 Vocabulary . j ava 

j*k 11 File(s) 97,227 bytes 

^Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
gfraXcoreXvocabularyXCVS 

•12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:20p 408 Entries 

12/16/99 06:20p 69 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

6 File(s) 1,369 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
fra\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:19p 48 Entries 

12/16/99 06:20p 78 Entries. Log 

12/16/99 06:19p 53 Repository 
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12/16/99 
12/16/99 



06:19p 
06:19p 

7 File(s) 



test 

4 6 Root 
846 Template 
1,071 bytes 



f ra\intercorecom 






12/06/00 


04:33p 


- 

<DIR> 




12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 


conf actory 


12/06/00 


04:33p 


<DIR> 


connectors 


12/06/00 


04:33p 


<DIR> 


CVS 


12/06/00 


04:33p 


<DIR> 


esip 


12/07/99 


04:26p 




303 Makefile 


12/06/00 


04:33p 


<DIR> 


proxy 


12/06/00 


04:33p 


<DIR> 


stacks 


12/06/00 


04:33p 


<DIR> 


util 




10 


File(s) 


303 bytes 



S Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
£f ra\intercorecom\conf actory 



112/06/00 
$2/06/00 
12/07/99 
J2/07/99 
.12/06/00 
142/07/99 
rpva 

rf 2/07/99 
§2/07/99 
42/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/06/00 
12/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:33p 
04:26p 

04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:2 6p 
04:26p 
04:33p 
04:2 6p 
04:33p 
04:26p 

17 File(s) 



<DIR> 
<DIR> 



<DIR> 



<DIR> 



<DIR> 



7,252 CFEvent Publisher. java 
6,288 CFStatistics. java 
co 

2,138 Communicat ionManagerException . j 

65,437 CommunicationManager . java 
7,656 ConnectionRegistry . java 
3,671 ConnectionEntry . java 
3,309 ConnFactoryTags . java 
6,409 ConnFactorySM. java 
4,682 ConnFactorylnfo. java 
2,133 CreateProxyException. java 
CVS 

502 Makefile 
policy 
3,523 Stat sUpdate. java 
113,000 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
fra\intercorecom\conf actory \co 



12/06/00 04:33p 
12/06/00 04:33p 
12/07/99 04:26p 



<DIR> 
<DIR> 



6,484 Connect ionObject . java 
Page 61 



test 

12/07/99 04:26p 2,892 Connectionlnf olntf . j ava 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 2,515 SerializationException . j ava 

12/07/99 04:26p 5,225 TCPConnectionlnf o . j ava 

7 File(s) 17,116 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\intercorecom\confactory\co\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:20p 244 Entries 

12/16/99 06:20p 80 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

6 File(s) 1,216 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
.^f ra\intercorecom\conf actory\CVS 

1*12/06/00 04:33p <DIR> 
,12/06/00 04:33p <DIR> 

$2/16/99 06:20p 694 Entries 

#2/16/99 06:20p 28 Entries. Log 

12/16/99 06:20p 77 Repository 

„!2/16/99 06:20p 46 Root 

;;i2/16/99 06:20p 846 Template 

U 7 File(s) 1,691 bytes 

^Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
!# ra\intercorecom\confactory\policy 

2(2/06/00 04:33p <DIR> 

'12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 13,446 Negotiator . j ava 

12/07/99 04:26p 14,105 NegotiationPolicy. java 

12/07/99 04:26p 4,684 NegotiationOf f er . j ava 

\V,lV,ll IV'V? 2 ' 348 Ne g°tiationFailedException.java 

12/07/99 04:26p 3,337 SecurityPolicy . j ava 

8 File(s) 37,920 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
±ra\xntercorecom\confactory\policy\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:20p 296 Entries 
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test 

12/16/99 06:20p 84 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

6 File(s) 1,272 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net \espeak\in 
f ra\intercorecom\connectors 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:26p 7,732 ConnectorManager . j ava 

12/07/99 04:26p 6,183 ConnectorDesc. java 

12/07/99 04:26p 4,495 Connector . java 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 5,514 DataConnector . java 

12/07/99 04:26p 3,714 ListeningConnector . j ava 

12/07/99 04:26p 557 Makefile 

12/07/99 04:26p 13,703 TcpDataConnector . j ava 

42/07/99 04:26p 7,334 TcpListeningConnector . java 

33.2/07/99 04:26p 6,420 TcpTunnelConnector . j ava 

%l 12 File(s) 55, 652 bytes 

fi Directory of E: \e-speak-src_9 91217 \platform\ES\src\java\net\espeak\in 
ijf ra\intercorecom\connectors\CVS 

^12/06/00 04:33p <DIR> 
.12/06/00 04:33p <DIR> 

lj.2/16/99 06:20p 508 Entries 

t f 2/16/99 06:20p 77 Repository 

42/16/99 06:20p 46 Root 

§.2/16/99 06:20p 846 Template 

Si 6 File(s) 1,477 bytes 

" Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\ inter corecom\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:20p 48 Entries 

12/16/99 06:20p 99 Entries. Log 

12/16/99 06:20p 66 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

7 File(s) 1,105 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
f ra\intercorecom\esip 
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12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/08/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04 :26p 
04:26p 
03:16p 
9 



<DIR> 
<DIR> 
<DIR> 



File(s) 



test 



CVS 

3,548 ESIPControlMessage. java 
5,727 ESIPExportMessage. java 
4,267 ESI PHeader. java 
4,123 ESIPMessage. java 
2,126 ESIPPayload. java 

461 Makefile 
20,252 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
f ra\intercorecom\esip\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
,42/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 

6 File(s) 



<DIR> 
<DIR> 



325 Entries 
71 Repository 
4 6 Root 

84 6 Template 
1,288 bytes 



^Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
Jfra\intercorecom\proxy 



IJ2/06/00 04:33p 

,12/06/00 04:33p 

,12/06/00 04:33p 

,12/07/99 04:26p 

|2/07/99 04:26p 

|2/C7/99 04:26p 

42/07/99 04:26p 

if2/07/99 04:26p 

12/07/99 04:26p 

12/07/99 04:26p 

12/07/99 04:26p 

12/07/99 04:26p 

12 File(s] 



<DIR> 
<DIR> 
<DIR> 



CVS 



2,166 
533 
12, 689 
27, 950 

8, 861 

9, 709 
36, 159 
26, 195 

3,882 
128, 14 



Ebyt eArrayOutput St ream . j a va 
Makefile 

ProxyAPIHandler . j ava 
ProxyExportHandler . j ava 
ProxyHelper . j ava 
ProxylmportHandler . j ava 
Proxy . java 
StateMgr . java 
Timeouts .java 
4 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\in 
f ra\intercorecom\proxy\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 



<DIR> 
<DIR> 



489 Entries 
72 Repository 
4 6 Root 

84 6 Template 



Page 64 



6 File(s) 



test 
1,453 bytes 



fra\intercorecom\ stacks 




12/06/00 


04:33p 


<DIR> 


12/06/00 


04:33p 


<DIR> 


12/06/00 


04:33p 


<DIR> 


12/07/99 


04:26p 




12/06/00 


04:33p 


<DIR> 


12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04:26p 






8 File(s) 





CVS 

5,443 LayerFactory. java 
layers 
457 Makefile 
4,429 StackBuilder. java 
14,775 Stack. java 
25,104 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\in 
f ra\intercorecom\stacks\CVS 

,«J.2/06/00 04:33p <DIR> 
112/06/00 04:33p <DIR> 

£5.2/16/99 06:20p 203 Entries 

12/16/99 06:20p 16 Entries. Log 

5J.2/16/99 06:20p 73 Repository 

;4l2/16/99 06:20p 46 Root 

=3.2/16/99 06:20p 846 Template 

jj[ 7 File(s) 1,184 bytes 

M Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
i=|fra\intercorecom\s tacks Mayers 

:;l2/06/00 04:33p <DIR> 

512/06/00 04:33p <DIR> 

42/07/99 04:26p 2,166 CILayer.java 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 3,461 Layerlntf . j ava 

12/07/99 04:26p 4,834 Layer. java 

12/07/99 04:26p 464 Makefile 

12/07/99 04:26p 7,071 NameAuthenticationLayer . java 

12/07/99 04:26p 2,221 TransportLayer . j ava 

9 File(s) 20,217 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
fra\intercorecom\stacks Mayers \CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:20p 316 Entries 

12/16/99 06:20p 80 Repository 
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12/16/99 
12/16/99 



06:20p 
06:20p 
6 



File(s) 



test 

4 6 Root 
846 Template 
1,288 bytes 



f ra\intercorecom\util 


12/06/00 


04 


: 33p 


12/06/00 


04 


:33p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


12/06/00 


04 


: 33p 


12/07/99 


04 


: 26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 



an 



<DIR> 
<DIR> 



<DIR> 



10 File(s) 



3,820 CondVar. java 

7, 348 ConnectionObjectFileReader . java 
CVS 

4,748 Header. java 
3,180 Lock. java 

439 Makefile 
3,276 Synchronizer . java 
3,090 VerifyDomain. java 
25,901 bytes 



;|Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
;/fra\intercorecom\util\CVS 



£12/06/00 
:il2/06/00 
$2/16/99 
.12/16/99 
.12/16/99 
LJL2/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 

<DIR> 



File (s) 



367 Entries 
71 Repository 
46 Root 

84 6 Template 
1,330 bytes 



jjDirectory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
-f ra\xml - 



'T2/06/00 


04 


:33p 


<DIR> 




12/06/00 


04 


:33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/07/99 


04 


:26p 




2, 931 


12/07/99 


04 


: 2 6p 




49, 369 


12/07/99 


04 


: 2 6p 




2, 453 


12/07/99 


04 


:26p 




6, 183 


12/07/99 


04 


:26p 




2,761 


12/07/99 


04 


:26p 




20,001 


12/06/00 


04 


: 33p 


<DIR> 


12/07/99 


04 


:26p 




515 


12/06/00 


04 


: 33p 


<DIR> 




12/07/99 


04 


:2 6p 




7, 355 


12/07/99 


04 


:26p 




4,425 


12/06/00 


04 


: 33p 


<DIR> 





CVS 

ESXMLDecoderlntf .java 
ESXMLDecoder . j ava 
ESXMLEncoder Int f . j ava 
ESXMLEncoder. java 
ESXMLShelllntf . j ava 
ESXMLShell. java 
IE5 

Makefile 
schema s 
XMLApp . j ava 
XMLNameList . j ava 
xml server 
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15 File(s) 



test 

95,993 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\xml\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
06:20p 
7 



<DIR> 
<DIR> 



File (s) 



481 Entries 
4 9 Entries. Log 
57 Repository 
4 6 Root 

84 6 Template 
1,479 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\in 
fra\xml\IE5 



12/06/00 
J.2/06/00 
4.2/06/00 
!€2/07/99 

12/07/99 
&2/07/99 
;Jl2/07/99 
il2/07/99 
! l l2/07/99 
12/07/99 
fl2/07/99 
;3.2/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 

12 File(s) 



<DIR> 
<DIR> 
<DIR> 



CVS 

854 e-speak_logo.gif 
1,792 lookup.htm 
3,320 lookup. js 

628 Readme.txt 
1,623 register.htm 
3,226 register. js 
3,631 response. js 
1,757 vocab.htm 
3,873 vocab.js 
20,704 bytes 



m Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\in 
:jfra\xral\IE5\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File (s) 



432 Entries 
61 Repository 
46 Root 
846 Template 
1,385 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\j ava\net\espeak\in 
f ra \xml \ s enema s 



12/06/00 04:33p 
12/06/00 04:33p 
12/06/00 04:33p 



<DIR> 
<DIR> 
<DIR> 



CVS 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:26p 
04:26p 
04:26p 
04:26p 
04:26p 

8 File(s) 



test 
4, 405 
368 
419 
589 
498 



es-basic. xsd 
es-lookup.xsd 
es-register.xsd 
es-response . xsd 
es-vocab.xsd 



6,279 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net \espeak\in 
fra\xml\schemas\CVS 



12/06/00 04:33p 



12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File (s) 



255 Entries 
65 Repository 
4 6 Root 
846 Template 
1,212 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\ 
: rf r a \ xml \ xml s e r ve r 



12/06/00 04:33p 



132/06/00 
! l2/06/00 
212/07/99 
U2/07/99 
12/07/99 
5 12/07/99 
:32/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 



<DIR> 
<DIR> 

<DIR> 



8 File(s) 



CVS 

5,2 91 ESXMLHttp. java 

3,218 ESXMLServerThread. java 

3,397 ESXMLServer. java 

314 Makefile 
8,305 TestServerApp. java 
20,525 bytes 



^Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\in 
^raXxmlXxmlserverXCVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File (s) 



266 Entries 
67 Repository 
4 6 Root 
84 6 Template 
1,225 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net \espeak\ je 
si J 



12/06/00 
12/06/00 
12/07/99 



04:33p 
04:33p 
04:26p 



<DIR> 
<DIR> 



7,741 AppSessionlDFilter. java 
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12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


12/06/00 


04 


: 33p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


.42/07/99 


04 


:26p 


.3.2/07/99 


04 


: 26p 


*12/07/99 


04 


:26p 


.32/07/99 


04 


:26p 


#2/07/99 


04 


:26p 


1412/07/99 


04 


:26p 


132/07/99 


04: 


:2 6p 


$2/07/99 


04: 


:26p 


1.12/07/99 


04: 


:2 6p 


12/07/99 


04: 


:26p 


:; 42/07/99 


04: 


:26p 


12/07/99 


04: 


:26p 


32/07/99 


04: 


: 26p 


$2/07/99 


04: 


:2 6p 


$2/07/99 


04: 


:2 6p 


12/07/99 


04: 


:26p 


12/07/99 


04 : 


26p 


12/07/99 


04 : 


2 6p 


12/07/99 


04: 


2 6p 


12/07/99 


04: 


26p 


12/07/99 


04: 


2 6p 


12/07/99 


04 : 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


2 6p 


12/07/99 


04 : 


26p 


12/07/99 


04 : 


26p 


12/07/99 


04 : 


26p 


12/07/99 


04: 


2 6p 


12/07/99 


04: 


26p 


12/07/99 


04 : 


26p 



test 

9,404 ClassDependencyFinder . java 
9,098 ClassFinder. java 
CVS 

3,496 ESContract. java 
55,605 ESAbstractFinder. java 
38,691 ESAbstractElement. java 

8,783 ESAccessRight. java 
47,370 ESAccessorStub. java 

2,293 ESAccessorHandle. java 
17,372 ESAccessor . java 

4,455 ESAppSessionlD. java 

3,690 ESAssert. java 

9,610 ESAttribute. java 
17,621 ESBaseServiceStub. java 

2,226 ESBaseService. java 

9,288 ESBaseQuery. java 
22,360 ESBaseDescription. java 

7,475 ESServiceDescription. java 

5,151 ESVocabularyElement . java 

2,374 ESService. java 

4,939 ESCallbacklntf . java 

7,132 ESCallbacklmpl. java 

2,478 ESCloneable. java 
12, 0 68 ESCommunity. java 
11,751 ESConfiguration. java 
18,190 ESConnector. java 
47,841 ESConnection. java 

6,580 ESConstants. java 

8,475 ESContractStub. java 

6,541 ESContract Finder. java 

7,474 ESContractElement. java 

7,914 ESContractDescription. java 
44,996 ESServiceElement . java 
12,517 ESServiceContext. java 

6,168 ESFolderFinder. java 
55,878 ESFolder. java 

3,806 ESHashMap. java 

6,331 ESHelper. java 

5,295 ESImplProxy. java 

2,228 ESIntrospectionlntf . java 

5,026 ESIntrospectionlmpl. java 

9,790 ESList.java 

1,977 ESManagementlntf . java 

2,633 ESMessageRegistrylntf . java 

4,917 ESMessage. java 
14, 917 ESMPM. java 

2,388 ESNameFactory. java 

3,755 ESQuery . java 
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1 9/07/Q9 

X £. / \J f / J Zs 


U 4 ■ ^1 \J p 


° 7 


1 9 /07 /99 


04 • 9 fin 


xo , 


1 9 /07 / QQ 


04 " 9 fin 


9 

Z , 


IP /Q7 /QQ 


0 4 • 9 fin 


a 

0 / 




04 ■ ?fin 


1 R 


1 9 /07 /QQ 
x z. / v / / y y 


04 - 9 fin 

U *i • Z Op 


91 
Zx , 




04 - 9 c n 

U *i • Z Op 


Q 


19/07/QQ 


0 4-9 fin 




19/07/99 


04 • 9 fin 

U *± > Z Op 




1 9 / 07 / Q Q 


04*9 fin 
U H . Z Op 


1 P 


19/07/Q9 
X Z. / \J / / y y 


0 4-9 fin 


9 

z / 


1 9 /07 / Q Q 


04 • 9 fin 

Ut . Z Op 


C 

Of 


1 9 / m / QQ 
X£ / \J 1 / y y 


0 4*9 fin 
u 4 . z op 


/I 

^ / 


1 9 /07 /QQ 

XZ / U / / 


0 4 • 9 fin 

U *i . Z. Op 




1 9 / 07 / Q Q 


0 4*9 fin 
U *i - Z Op 


fi 


1 9/07 /QQ 
x*L f \) i f yy 


04-9 fin 

\J *i . Z up 


90 

Z U / 


1 9 /m /QQ 
XZ / U 1 / yy 


U ^± - Z op 




19/07/QQ 
X Z. / \J f / y y 


0 4*9 fin 
U *i • Z Op 


p 


19/07/QQ 


0 4-9 £n 

u ^ . z op 




! s j 9 / n 7 / QQ 


0 4*9 £r-> 

U *± . z op 




€2/07/99 


04:26p 


5, 


"12/06/00 


04:33p <DIR> 




it2/07/99 


04:26p 




j j2/07/99 


04:26p 


2, 


32/06/00 


04:33p <DIR> 






76 File(s) 


7 Q Q 
/ 0 0 


; Directory of E:\e-speak-src 9< 


51917 


!|i\CVS 






3f2/06/CC 


04:33p <DIR> 




22/06/00 


04:33p <DIR> 




3f2/16/99 


06:20p 


3, 


! #2/16/99 


06:20p 




12/16/99 


06:20p 




12/16/99 


06:20p 




12/16/99 


06:20p 






7 File(s) 


4 


Directory of E:\e-speak-src 991217 


si\event 






12/06/00 


04:33p <DIR> 




12/06/00 


04:33p <DIR> 




12/06/00 


04:33p <DIR> 




12/06/00 


04:33p <DIR> 




12/07/99 


04:26p 


15, 


12/07/99 


04:26p 


2, 



St 

18 9 ESRunnable. java 
633 ESScope.java 
564 ESSecuritylntf . java 
649 ESServiceStub. java 
986 ESServiceMessenger . java 
090 ESServiceHandler . java 
170 ESServiceFinder . java 
507 ESSessionlntf . java 
693 ESSessionlmpl .java 
154 ESStartService . java 
223 ESStubFactorylntf . java 
8 67 ESStubFactorylmpl. java 
213 ESThread. java 
909 ESUniqList. java 
042 ESUserCredential. java 
618 ESVocabularyDescription . j ava 
8 68 ESVocabulary . j ava 
682 ESVocabularyStub . j ava 
647 ESVocabularyFinder . java 
243 ESXMLFile. java 
276 ESXMLQuery. java 
event 

290 GenericClassLoader . java 
169 Makefile 

management 
,790 bytes 

\platf orm\ES\src\ java\net\espeak\ je 



944 Entries 

35 Entries. Log 

52 Repository 

4 6 Root 
84 6 Template 
,923 bytes 

\platf orm\ES\src\java\net\espeak\ je 



coredist 
CVS 

259 ESCoreSubscriber . java 
359 ESCoreListenerlntf . java 
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test 



1 9 /07 / QQ 


U *i 






1 4 4 9 6 
±H f H zo 


LOUlb LI XJjUUOI . J a V a. 


1 9/07 /QQ 


04 






O / t O X 


HiOiiXo Ltrlitr X. O L, U.JJ . Java 


1 9 /07 /QQ 


04 


• z op 




9 777 
Z r f f / 


U" 1 CT *i' o ~t~ £\ vi /-\ v T ri +■ "F ~i ^ tt ~~i 

xjOlilSLcIierinui. . J aVa 


1 o / n 7 / QQ 


u ^ 


. z bp 




c £ £ n 


iiib rUDiisnerotiuD . ]ava 


1 o / n 7 / QQ 
1Z / v f / yy 


d A 


. z op 






hbrUDiisner intr . 3 ava 


1 9 /H7 /QQ 


n /i 

U 4 






on cno 
ZU f okjz 


tibrUDiisner . 3 ava 


1 9/07 / QQ 

XZ / W / / _7Z? 


04 






1 7 QQQ 


LjO O UkJo LL X.AJt?X . Java 


1 9 /D 7 /QQ 
±Z / U / / y 


U 4 


r 2 6p 




9 n ^ q 


EventException . j ava 


12/06/00 


04 




<DTR> 




1 1 
XIU]J X 


12/06/00 


04 


:33p 


<DIR> 




intf 


12/07/99 


04 


:26p 




730 


Makefile 


12/07/99 


04 


:26p 




5,740 


Publisherlnf o.java 


12/07/99 


04 


:26p 




4, 843 


ResultSetEntry . j ava 


12/07/99 


04 


:26p 




5,769 


ResultSet . j ava 


12/06/00 


04 


:33p 


<DIR> 




util 



21 File(s) 107,193 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\ je 
si\event\coredist 



12/06/00 


04 


: 33p 


<DIR> 








lfe/06/00 


04 


:33p 


<DIR> 








! fe/07/99 


04 


:26p 




6, 908 


CoreSubProf ile . j ava 




lfe/06/00 


04 


: 33p 


<DIR> 




CVS 




§2/07/99 


04 


:26p 




3,621 


ESCoreListenerStub . j ava 


92/07/99 


04 


:26p 




4,352 


ESCoreDistributorStub . 


java 


j f2/07/99 


04 


:26p 




3,343 


ESCoreDistributorlntf . 


java 


12/07/99 


04 


:26p 




8,886 


ESCoreDistributorlmpl . 


java 


12/07/99 


04 


:26p 




485 


Makefile 








9 


File(s) 


27,595 bytes 





:Sf)irectory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\ je 
&L\event\coredist\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File (s) 



353 Entries 
67 Repository 
4 6 Root 
84 6 Template 
1,312 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\je 
si\event\CVS 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:20p 772 Entries 



Page 71 



test 

12/16/99 06:20p 60 Entries. Log 

12/16/99 06:20p 58 Repository 

12/16/99 06:20p 46 Root 

12/16/99 06:20p 846 Template 

7 File(s} 1,782 bytes 



si\event\impl 




12/06/00 


04:33p 


<DIR> 


12/06/00 


04 :33p 


<DIR> 


12/06/00 


04:33p 


<DIR> 


12/07/99 


04:26p 




12/07/99 


04:26p 




ava 






12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04:26p 




..12/07/99 


04:26p 




'32/07/99 


04:26p 






10 


File(s) 



CVS 

11,967 DistributorStore . java 
10, 316 ESEventServiceComponentHelper. j 

17,224 ESEventServiceComponent . j ava 
12, 805 ESEventDistributorlmpl. java 
510 Makefile 
5,724 RegisterEventABI. java 
4,909 SubsDet.java 
63,455 bytes 

^Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\ je 
;^i\event\impl\CVS 

S2/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

&2/16/99 06:20p 413 Entries 

^2/16/99 06:20p 63 Repository 

#2/16/99 06:20p 46 Root 

32/16/99 06:20p 846 Template 

i|| 6 File(s) 1,368 bytes 

"Directory of E:\e-speak-src 



si\event\intf 




12/06/00 


04:33p 


<DIR> 


12/06/00 


04:33p 


<DIR> 


12/06/00 


04:33p 


<DIR> 


12/07/99 


04 :26p 




12/07/99 


04 :26p 




y . j ava 






12/07/99 


04:2 6p 




12/07/99 


04:2 6p 




12/07/99 


04:26p 




ry . java 






12/07/99 


04:26p 




12/07/99 


04:26p 





CVS 

10,752 ESDistributorStub. java 
3, 317 ESDistributorlntfMessageRegistr 

4,324 ESDistributorlntf . java 
11,792 ESEventServiceStub. java 
3, 320 ESEventServicelntfMessageRegist 

2,865 ESEventServicelntf . java 
4, 945 ESListenerlntfMessageRegistry . j 
Page 72 



test 



ava 

12/07/99 04:26p 
java 

12/07/99 04:26p 

12 File(s) 



3, 346 ESPublisherlntfMessageRegistry 

613 Makefile 
45,274 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\ j 
si\event\intf \CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04 :33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 
6 



<DIR> 
<DIR> 



File (s) 



578 Entries 
63 Repository 
4 6 Root 
846 Template 
1,533 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\ j 
soAeventXutil 



ife/06/00 
$2/06/00 
£"2/07/99 
|fe/06/00 
12/07/99 
life / 0 7 / 9 9 
12/07/99 
12/07/99 
j$2/07/99 
12/07/99 
1*2/07/99 
1*2/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:26p 
04 :33p 
04:2 6p 
04:26p 
04:26p 
04 :26p 
04:26p 
04 :26p 
04 :26p 
04:26p 
04:26p 
04:2 6p 
14 



<DIR> 
<DIR> 

<DIR> 



File (s) 



4,68 6 CoreEventPredicate. java 
CVS 

5,530 EventContext . java 
3,78 3 EventDataTypes . java 
8,788 Even tMapEntry. java 
8,550 Even tMap. java 
8,253 EventPredicate. java 
5,526 Id. java 
6,323 Input Info. java 

551 Makefile 
6,391 PubProfile. java 
9,576 SubProf ile . java 
67, 957 bytes 



Directory of E : \e-speak-src_991217 \platf orm\ES\src\ j ava\net\espeak\ j 
si\event\util\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:20p 
06:20p 
06:20p 



<DIR> 
<DIR> 



6 File(s) 



578 Entries 
63 Repository 
4 6 Root 

84 6 Template 
1,533 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\ j 
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si\management 



test 



12/06/00 

12/06/00 

12/07/99 

12/07/99 

12/06/00 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

ry. java 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

0,2/07/99 

t2/07/99 

12/07/99 

=12/07/99 

jfe/07/99 

lfe/07/99 

112/07/99 

I&/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:33p 
04:2 6p 
04:26p 
04:2 6p 
04:26p 
04:26p 
04:26p 

04:2 6p 
04:26p 
04:2 6p 
04 :26p 
04:26p 
04 :26p 
04 :26p 
04:26p 
04:26p 
04:2 6p 
04:26p 
04:26p 
23 



<DIR> 
<DIR> 



<DIR> 



File(s) 



12, 092 AbstractManagedServi.ee. java 
2, 703 CoreConnectionException. java 
CVS 

2, 672 IllegalStateTransition.esidl 

2, 415 IllegalStateTransition. java 

1,135 Makefile 
12,899 ManagedServicelntf . esidl 
15,798 ManagedServiceStub. java 

2, 306 ManagedServicelntfMessageRegist 

12,899 ManagedServicelntf . java 
3,496 ManageableService. java 
2,680 NoSuchVariableName. esidl 
2,395 NoSuchVariableName. java 
1,748 ResourceEntry. esidl 
2,800 ResourceEntry . java 
6,580 ServiceContext. java 

6.096 SimpleManagedService. java 
1,770 VariableType. esidl 

3.097 VariableType. java 
1,965 VariableEntry. esidl 
2,734 VariableEntry. java 

100,280 bytes 



jlPirectory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\ je 
sji \management \CVS 



1=2/0 6/00 
ife/06/00 
T2/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04 :33p 
06:20p 
06:20p 
06:20p 
06:20p 



<DIR> 
<DIR> 



6 File(s) 



1,191 Entries 
63 Repository 
4 6 Root 
84 6 Template 
2,146 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/06/00 
12/06/00 



04:33p 
04:33p 
04:33p 
04:26p 
04:33p 
04 :33p 



<DIR> 
<DIR> 
<DIR> 

<DIR> 
<DIR> 



advertise 
14 9 compile.bat 
CVS 

events 
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12/07/99 04:26p 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
9 File(s) 



test 

269 Makefile 
management 
tunnel 
418 bytes 



rvices\advertise 




12/06/00 


04 




<DIR> 


12/06/00 


04 




<DIR> 


12/06/00 


04 


« _> *J 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/07/99 


04 


:26p 




12/07/99 


04 


:26p 




12/06/00 


04 


:33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


:33p 


<DIR> 


,42/07/99 


04 


:2 6p 




! lf2/07/99 


04 


:26p 




fc/07/99 


04 


:26p 




^2/06/00 


04 


: 33p 


<DIR> 


lS2/06/00 


04 


: 33p 


<DIR> 


|2/06/00 


04 


: 33p 


<DIR> 


112/06/00 


04 


: 33p 


<DIR> 



17 File(s; 



agents 
bin 

clientapi 
1,055 compile.bat 
143 co.MYCOs 
CVS 

discovery 

exception 
325 Makefile 
668 makefile . release 
131 object-class-definition 

query_parser 

util 

yp common 
ypserver 
2,322 bytes 



^Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\se 
i|jvices\advertise\agents 



;p/06/00 
12/06/00 
fe/07/99 
T2/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:26p 
04 :26p 
04:33p 
04:26p 
04 :2 6p 
04:26p 

8 File(s) 



<DIR> 
<DIR> 



<DIR> 



14,434 AdvLSAgent. java 
5,019 BackendAgentlntf . java 
CVS 

4 5,917 LDAPDirAgent. java 
441 Makefile 
6,372 ProxySocketFactory. java 
72,183 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\advertise\agents\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 



04 ; 
04: 
06: 
06: 
06: 



33p 
33p 
2 Op 
2 Op 
2 Op 



<DIR> 
<DIR> 



272 Entries 
73 Repository 
4 6 Root 



Page 75 



12/16/99 06:20p 

6 File(s) 



test 

84 6 Template 
1,237 bytes 



rvices\advertise\bin 






12/06/00 


04 ■ 33d 


<DIR> 




12/06/00 


04 : 33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




12/07/99 


04 :26p 




607 


12/07/99 


04 :26p 




640 


12/07/99 


04:26p 




599 


12/07/99 


04:2 6p 




580 


12/07/99 


04 :26p 




585 


12/07/99 


04:26p 




549 


12/07/99 


04:26p 




585 


12/07/99 


04:2 6p 




549 


12/07/99 


04:26p 




673 


; 12/07/99 


04 :26p 




635 




13 File(s) 




6,002 



CVS 

runas_ldap.bat 
runas_ldap 
runas_noldap 
runas_noldap . bat 
runas_ldap_s 
runas_ldap_s . bat 
runas__ldap_i_s 
runas_ldap_i_s . bat 
runas_ldap_i 
runas_ldap_i . bat 
bytes 



directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\se 
p|jp"ices\advertise\bin\CVS 

12/06/00 04:33p <DIR> 
O/06/00 04:33p <DIR> 

12/16/99 06:20p 513 Entries 

0,2/16/99 06:20p 70 Repository 

W/16/99 06:20p 46 Root 

|f>/16/99 06:20p 846 Template 

131 6 File(s) 1,4 75 bytes 

.directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\advertise\clientapi 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

19/nT / qq nV'l? 23 ' 009 ESADServicelnterface.java 

12/07/99 04:26p 376 Makefile 

5 File(s) 23,385 bytes 

Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\se 
rvices\advertise\clientapi\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:21 P 110 Entries 
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12/16/99 
12/16/99 
12/16/99 



06:20p 
06:20p 
06:20p 

6 File(s) 



test 

7 6 Repository 
4 6 Root 
84 6 Template 
1,078 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\ 
rvices\advertise\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04 :33p 
04:33p 
06:20p 
06:21p 
06:20p 
06:20p 
06:20p 

7 File(s) 



<DIR> 
<DIR> 



254 Entries 
158 Entries. Log 

66 Repository 

4 6 Root 
84 6 Template 
1,370 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\ 
juices \advertise\discovery 



12/06/00 04:33p <DIR> 

,12/06/00 04:33p <DIR> 

'fZ/Ql/99 04 :26p 

:^/07/99 04:26p 

112/07/99 04:26p 

•fe/07/99 04:26p 

l = 2/07/99 04:2 6p 

12/07/99 04:26p 

S2/07/99 04:2 6p 

ft/07/99 04:26p 

|fe/07/99 04:26p 

ft/07/99 04:26p 

ft/06/00 04:33p <DIR> 

1*2/07/99 04:26p 

14 File(s) 



4,005 AdvDscvMsgBag. java 
1,992 AdvDscvMsg. java 
4,022 AdvIncomingDscvRqst . java 
4,575 AdvIncomingDscvRply. java 
12, 183 AdvMcastSenderReceiver . java 
3,810 AdvOutgoingDscvRqst . java 
7,24 7 AdvOutgoingDscvRply . java 
4,52 4 AdvSLPOutgoingMsg. java 
3,33 6 AdvSLPMsg. java 
7,123 AdvSLPIncomingMsg. java 
CVS 

640 Makefile 
53,457 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net \espeakV 
rvices\advertise\discovery\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File(s) 



632 Entries 
7 6 Repository 
4 6 Root 
846 Template 
1,600 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\: 

Page 77 



rvi ce s\ advert ise\except ion 



test 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
9 



<DIR> 
<DIR> 



<DIR> 



File(s) 



3,118 AdvException . java 
3, 237 AdvNoSuchBackendExcept ion. java 
CVS 

3,08 9 IllegalArgument . java 

490 Makefile 
3,175 NoADServiceExcept ion . j ava 
3,14 8 ParseErrorExcept ion. java 
16,257 bytes 



Directory of E: \e-speak-src_991217\platf orra\ES\src\ java\net\espeak\se 
rvices\advertise\exception\CVS 



12/06/00 
12/06/00 
12/16/99 
3*2/16/99 
fc/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 

6 File(s) 



<DIR> 
<DIR> 



349 Entries 
7 6 Repository 
4 6 Root 

84 6 Template 
1,317 bytes 



directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\se 
:gvices\advertise\query_parser 



12/06/00 
12/06/00 
Jfe/06/00 
ife/07/99 
fe/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 


<DIR> 




04:33p 


<DIR> 




04:33p 


<DIR> 




04:2 6p 




2, 505 


04:26p 




747 


04 :26p 




3,408 


04 :26p 




4,285 


04 :26p 




5,451 


04:2 6p 




4,077 


04 :2 6p 




3, 667 


04:26p 




3,095 


04:26p 




3,101 


04:26p 




2,252 


04:26p 




3,073 


04:26p 




2, 636 


04:26p 




17,430 


04:26p 




3,097 


04:26p 




3,498 


04:26p 




3, 825 


04:26p 




4,373 


04:26p 




14, 678 
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CVS 

LDAPQueryOps . j ava 
Makefile 

QueryLeaf Node . j ava 
QueryAndNode . j ava 
QueryComparatorNode . j ava 
QueryExprNode . j ava 
QueryEqNode . j ava 
QueryGtNode . j ava 
QueryGeNode . j ava 
Queryldentif ierNode . j ava 
QueryLtNode . j ava 
QueryLiteralNode . j ava 
QueryLex. java 
QueryLeNode . j ava 
QueryNotNode . j ava 
QueryNeqNode . j ava 
QueryOrNode . j ava 
QueryPar ser . j ava 



21 File(s) 



test 

85,198 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\ 
rvices\advertise\query parser \CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



975 Entries 
79 Repository 
4 6 Root 
84 6 Template 
1,946 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\ 
rvices\advertise\util 



12/06/00 
12/06/00 
12/06/00 
112/07/99 
3-2/07/99 
Ji2/07/99 
i3j2/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04 :26p 
04 :26p 
04 :26p 
04 :26p 



<DIR> 
<DIR> 
<DIR> 



8 File(s) 



CVS 

3,428 eskill.java 

424 Makefile 
5,560 Multicaster . java 
2,191 Shutdownlntf . java 
6,600 ShutdownCtrl . java 
18,203 bytes 



!/ Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\ 
:r:vices\advertise\util\CVS 



$2/06/00 

Jfe/06/00 
&/16/99 
Ife/16/99 
T2/16/99 
12/16/99 



04 :33p 
04 : 33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s] 



257 Entries 
71 Repository 
4 6 Root 
84 6 Template 
1,220 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\ 
rvices\advertise\ypcommon 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:33p 
04:26p 
04 :2 6p 
04:26p 



<DIR> 
<DIR> 



<DIR> 



2,24 9 AdvDebug . j ava 
6,157 ArraySet . java 
CVS 

689 Makefile 
2,4 65 QueryOps . java 
2,537 YPCompBigDecimal. java 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04 :26p 
04:26p 
04:26p 
04 :26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:2 6p 

20 File(s) 



test 

2,451 YPCompFloat. java 
9,801 YPComparator. java 
2,430 YPCompByte. java 
2,442 YPCompDouble. java 
2,566 YPComparable . java 
2,353 YPCompString. java 
2,430 YPCompShort. java 
2,418 YPCompLong . j ava 
2,439 YPCompInt . java 
2,504 YPCompChar. java 
2,087 YPObjects. java 
2,745 YPOperations . java 
50,763 bytes 



Directory of E: \e-speak-src_991217\platforra\ES\src\java\net\espeak\se 
rvices\advertise\ypcommon\CVS 



12/06/00 
,42/06/00 

12/16/99 
$2/16/99 
:i2/16/99 
&/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File(s) 



890 Entries 
75 Repository 
4 6 Root 

84 6 Template 
1,857 bytes 



^Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\ 
rvices\advertise\ypserver 



se 



H2/06/00 
ft/06/00 
j|s/07/99 
|;2/07/99 
§2/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04 :26p 
04:2 6p 
04:26p 
04:26p 
04:33p 
04:26p 
04 :2 6p 
04 :26p 
04:26p 
04:2 6p 
04:2 6p 
04 :26p 
04:26p 
04:26p 
16 



<DIR> 
<DIR> 



<DIR> 



File (s) 



8 8,2 92 Advert isingService. java 
4,168 BackendLookupResult . java 
5,140 BackendConnectionlnfo. java 

16,210 ConnectionManager . java 
CVS 

ExternalEsrl . j ava 
Makefile 

TimeoutHandler . j ava 
YPGenericTable . j ava 
YPItemsTable . j ava 
YPItem. java 
YPMessage. java 
YPSearchResultsTable , 
YPSearchResult . j ava 



4,733 
651 

4, 138 

5, 346 
5, 438 
4, 980 
3,221 
3,821 
9, 852 



. java 



155,990 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvaces\advertise\ypserver\CVS 
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test 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



728 Entries 
75 Repository 
46 Root 

84 6 Template 
1,695 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\ 
rvices\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:20p 
06:21p 
06:20p 
06:20p 
06:20p 
7 



<DIR> 
<DIR> 



File(s) 



96 Entries 
71 Entries. Log 
56 Repository 
4 6 Root 
84 6 Template 
1,115 bytes 



^Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\s 
iCvicesXe vents 



12/06/00 
i'2/06/00 
12/07/99 
2,2/06/00 
14=2/07/99 
fc/07/99 
!&/07/99 
12/07/99 
&/07/99 



04 


: 33p 


<DIR> 


04 


:33p 


<DIR> 


04 


:26p 




04 


: 33p 


<DIR> 


04 


: 2 6p 




04 


:26p 




04 


:26p 




04 


:26p 




04 


: 2 6p 






9 


File (s) 



697 compile.bat 
CVS 

5,926 ESCoreDistributor. java 

5, 093 ESManagementDistributor . java 

3,995 ESServiceDistributor. java 

465 Makefile 

510 makefile . release 
16, 686 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\s 
rvices\events\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File(s; 



335 Entries 
63 Repository 
4 6 Root 
84 6 Template 
1,290 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\s< 
rvices \managentent 
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test 



12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


:33p 


<DIR> 


12/07/99 


04 


:26p 




12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


:33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/07/99 


04 


:26p 




12/07/99 


04 


:26p 




12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 



12 File(s) 



1,328 compile.bat 
coremanager 
CVS 

logger 

333 Makefile 

759 makefile . release 
policymanager 
processmanager 
servicemanager 
web 
2,420 bytes 



Directory of E : \e-speak-src_991217 \platf orm\ES\src\ j ava\net\espeak\se 
rvices \management \cor emanager 



15/06/00 
K/06/00 
U/07/99 
£2/07/99 
US / 0 7 / 9 9 
il/07/99 
52/07/99 
il/07/99 
12/07/99 
12/07/99 
lg/07/99 
33/07/99 
lf/07/99 
i§/06/00 
£1/07/99 
12/07/99 
12/07/99 
12/07/99 
12/15/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:26p 
04 :26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04 :26p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:00p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 

27 File(s) 



<DIR> 
<DIR> 



<DIR> 



27,653 CoreManager. java 

20,917 CoreManagerMSImpl . java 

12,661 CoreManagerOS . j ava 

19,588 CoreManagerMS . java 
705 compile.bat 
7, 599 CoreEventSubscriberlmpl. java 
5,247 CoreEventSubscriber . java 
7,420 CoreManagerTags . java 
6,473 CoreManagerStats. java 
4,484 CoreManagerOSIntf . java 

23,110 CoreManagerOS Impl . java 
CVS 

4,14 8 DbgLog.java 

6,24 9 Event Publisher . java 

8, 116 ExtEventSubscriberlmpl. java 

4,622 ExtEventSubscriber. java 
931 Makefile 
527 makefile. release 

5,151 ServiceDataList . java 

3,528 Shutdown. java 

5,112 StateMC.java 

4,434 Staticlnfo. java 
10,091 StatsReader. java 

3,785 StatsStore. java 

6,651 UpdateStats . java 
199,202 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\se 
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test 

rvices\management\coremanager\CVS 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:21p 1,324 Entries 

12/16/99 06:21p 79 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

6 File(s) 2,295 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\s 
rvices\management\CVS 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:21p 149 Entries 

12/16/99 06:21p 121 Entries. Log 

12/16/99 06:21p 67 Repository 

12/16/99 06:21p 46 Root 

!|fe/16/99 06:21p 846 Template 

•y 1 File(s) 1,229 bytes 

^Directory of E : \e-speak-src_991217 \platf orm\ES\src\ java\net\espeak\s< 
ices \management \ logger 

12/06/00 
12/06/00 
12/06/00 
12/06/00 
&/07/99 
12/06/00 
fe/06/00 
p/06/00 
T2/06/00 
12/06/00 
12/06/00 



Directory of E : \e-speak-src_991217 \platf orm\ES\src\ java\net \espeak\s 
rvices\management\logger\client 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 4,325 ESLogClient . j ava 

12/15/99 04:00p 434 Makefile 

5 File(s) 4,759 bytes 



04 :33p 


<DIR> 




04:33p 


<DIR> 




04 :33p 


<DIR> 


client 


04:33p 


<DIR> 


CVS 


04 :26p 




333 Makefil 


04:33p 


<DIR> 


manager 


04:33p 


<DIR> 


message 


04:33p 


<DIR> 


service 


04:33p 


<DIR> 


test 


04 :33p 


<DIR> 


types 


04:33p 


<DIR> 


util 


11 


File (s) 


333 bytes 
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test 

Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\ 
rvices\management\logger\client\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File(s) 



101 Entries 
81 Repository 
4 6 Root 

84 6 Template 
1,074 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net \espeak\ 
rvices\management\ logger \CVS 



12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:21p 

12/16/99 06:21p 

0,2/16/99 06:21p 

1-2/16/99 06:21p 

§2/16/99 06:21p 

ui 7 File (s) 



<DIR> 
<DIR> 



48 Entries 
110 Entries. Log 

7 4 Repository 

4 6 Root 
84 6 Template 
1,124 bytes 



|JjDirectory of E : \e-speak-src_991217 \platf orm\ES\src\ j ava\net\espeak\ 
iifvices \management \ logger \manager 



12/06/00 
12/06/00 
$2/06/00 
^2/07/99 
3(2/07/99 
fe/07/99 
12/15/99 



04:33p 
04:33p 
04:33p 
04 :26p 
04 :26p 
04 :26p 
04:00p 

7 File(s) 



<DIR> 
<DIR> 
<DIR> 



CVS 

9,765 ESLogServiceServlet . j ava 

69 ESLogServiceManager .propertie 
7,964 ESLogServiceManager. j ava 

473 Makefile 
18,271 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\ 
rvices\management\logger\manager\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04 :33p 
04 :33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File(s) 



237 Entries 
82 Repository 
4 6 Root 

84 6 Template 
1,211 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\; 
rvices\management\ logger Ymessage 
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test 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 
5 



<DIR> 
<DIR> 
<DIR> 



File(s) 



CVS 

13,666 ESLogMessage . java 
405 Makefile 
14,071 bytes 



Directory of E: \e-speak-src_991217 \platf orm\ES\src\ java\net\espeak\se 
rvices\management\logger\message\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04 :33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



102 Entries 
82 Repository 
4 6 Root 

84 6 Template 
1,076 bytes 



JjDirectory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
<|pices\management\logger\service 



12/06/00 

fe/06/00 

12/06/00 

12/07/99 

12/07/99 

12/07/99 

li2/07/99 

.12/07/99 

|2/07/99 

;rrj ava 

f-2/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 



04:33p 
04:33p 
04 :33p 



<DIR> 
<DIR> 
<DIR> 



:26p 
2 6p 
26p 
26p 
2 6p 
26p 

26p 
2 6p 
26p 
2 6p 
04:2 6p 
04:26p 
04:26p 
04:26p 
17 



04 
04 
04 
04 
04 
04 

04; 
04 : 
04: 
04: 



File(s) 



CVS 

18,657 ESLogFileWriter. java 

3,693 ESLoggerWaitQueue. java 
16,773 ESLogMessageParser . java 

2,281 ESLogServicelntf .esidl 

4,131 ESLogServiceStub. java 

1, 135 ESLogServicelntfMessageRegistry 

2,281 ESLogServicelntf . java 

3,737 ESLogServicelmpl . java 

741 Makefile 

2, 727 ServicePackageWhiteBoxTest . java 

4,995 TestDenialOf Service. java 

4,380 TestEscapeProcessing. java 

12,892 Test FileWriting. java 

6,023 TestQueueProcessing. java 
84,446 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\se 
rvices\management\logger\service\CVS 



12/06/00 04:33p 
12/06/00 04:33p 
12/16/99 06:21p 



<DIR> 
<DIR> 



839 Entries 
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12/16/99 
12/16/99 
12/16/99 



06:21p 
06:21p 
06:21p 

6 File(s) 



test 

82 Repository 
4 6 Root 
84 6 Template 
1,813 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\s 
rvices\management\logger\test 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:2 6p 
04:2 6p 
6 



<DIR> 
<DIR> 
<DIR> 



File(s) 



CVS 

2,058 ESLoggerTest . java 
4,297 ESLoggerDefaultTest. java 
403 Makefile 
6,758 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\s< 
rvices\management\logger\test\CVS 



112/06/00 
fe/06/00 
ft/16/99 
152/16/99 
^2/16/99 
ite/16/99 



04:33p 
04 :33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File(s) 



163 Entries 
7 9 Repository 
4 6 Root 

84 6 Template 
1,134 bytes 



directory of E:\e-speak-src_991217\platforra\ES\src\java\net\espeak\s 
Ibices \management\logger\ types 



•12/06/00 
fe/06/00 
ft/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04 :26p 
04:26p 
04:26p 
04 :2 6p 
04 :26p 
04:26p 
04:26p 
04:26p 
11 



<DIR> 
<DIR> 
<DIR> 



File (S) 



CVS 

3,888 ESLoggableDataltem. java 
4, 928 ESLoggableDatal temList . j ava 
3,4 85 ESLoggableBoolean. java 
3,481 ESLoggableString. java 
3,531 ESLoggablelnteger . java 
3,529 ESLoggableFloat. java 
4,459 ESLoggableDate. java 

547 Makefile 
27,848 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\s< 
rvices\management\logger\types\CVS 



12/06/00 04:33p 
12/06/00 04:33p 



<DIR> 
<DIR> 
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test 

12/16/99 06:21p 461 Entries 

12/16/99 06:21p 80 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

6 File(s) 1,433 bytes 

Directory of E: \e-speak-src_991217\platf orra\ES\src\ java\net\espeak\se 
rvices\management\logger\util 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 2,286 ESLoggableDateFormat . j ava 

12/07/99 04:26p 381 Makefile 

5 File(s) 2,667 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\management\logger\util\CVS 

S/06/00 04:33p <DIR> 
ft/06/00 04:33p <DIR> 

ife/16/99 06:21p 110 Entries 

|?/16/99 06:21p 79 Repository 

|2/16/99 06:21p 46 Root 

11/16/99 06:21p 846 Template 

£ 6 File(s) 1,081 bytes 

^Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net \espeak\se 
^yices\management\policymanager 

ii/06/00 
31/06/00 

E?/06/00 04:33p <DIR> CVS 

H/06/00 04:33p <DIR> filingsystem 

12/15/99 ~- ~- 
12/07/99 
a 

12/07/99 
12/07/99 
12/07/99 
12/07/99 
ava 

12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
Registry . java 



04:33p 


<DIR> 




04:33p 


<DIR> 




04:33p 


<DIR> 




04:33p 


<DIR> 




04 :00p 




1, 397 


04:26p 




2,330 


04:26p 




2,207 


04:26p 




5,198 


04:26p 




30,027 


04:26p 




2,145 


04:26p 




3, 828 


04:26p 




4,792 


04:26p 




2,819 


04:26p 




2,708 


04:26p 




1, 817 
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test 


12/07/99 


04:2 6p 




6,568 


12/07/99 


04:26p 




2, 392 


12/07/99 
a 


04:26p 




3, 000 


12/07/99 


04:26p 




2,400 


12/07/99 


04:26p 

ST 




2, 694 


. j ava 








12/07/99 


04 :2 6p 




2, 247 


java 








12/07/99 


04:26p 




2,225 


va 








12/07/99 


04:26p 




2, 219 


12/07/99 


04 :26p 




2, 549 


• java 








12/07/99 


04:26p 




1, 394 


y . j ava 








12/07/99 


04 :26p 




5,720 


12/07/99 


04:26p 




24, 384 


12/07/99 


04:26p 




4 , 792 


$2/07/99 


04:26p 




6,112 


12/07/99 


04:26p 




2,188 


1;fener. java 






12/07/99 


04:26p 




2,069 


j%t . j ava 








52/06/00 


04:33p 


<DIR> 





1, 394 PolicyManagerlntfMessageRegistr 



32 File(s) 



2,069 PolicyManagerFactoryShutdownEve 

servlet 
132,221 bytes 



^Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\ 
ftvices\management\policymanager\CVS 



se 



18/06/00 
£2/06/00 
#4/16/99 
1*2/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
06:21p 
7 



<DIR> 
<DIR> 



File (s) 



1,805 Entries 

39 Entries. Log 
81 Repository 
4 6 Root 
846 Template 
2,817 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\se 
rvices\management\policymanager\filingsystem 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
va 

12/06/00 



04:33p 
04:33p 
04:26p 
04:26p 

04:33p 



<DIR> 
<DIR> 



<DIR> 



8,047 ChangeList . java 

1, 931 CorruptedPolicyFileException. ja 



CVS 
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12/07/99 04:26p 
12/07/99 04:26p 
12/07/99 04:26p 
12/07/99 04:26p 
java 

12/07/99 04:26p 
properties 
12/15/99 04:00p 
12/07/99 04:26p 

12 File(s) 



test 

13,747 FileFormatter. java 

9,032 FileLoader. java 

5,168 FileUtil. java 
17, 791 FilingSystemPersistencyManager . 

33 FilingSystemPersistencyManager . 

590 Makefile 
11,933 PolicyManagerFile . j ava 
68,272 bytes 



Directory of E : \e-speak-src_9912 17 \platf orm\ES\src\ j ava\net \espeak\se 
rvices\management\policymanager\f ilingsystem\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
.12/16/99 
;lfe/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File(s) 



536 Entries 
94 Repository 
4 6 Root 

84 6 Template 
1,522 bytes 



'•^Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\se 
jf ices\management\policymanager\servlet 



12/06/00 
12/06/00 
12/06/00 
42/15/99 
ft/07/99 



04:33p 
04:33p 
04:33p 
04 :00p 
04:26p 
5 



<DIR> 
<DIR> 
<DIR> 



File (s) 



CVS 

424 Makefile 
16,601 PolicyManagerServlet , 
17,025 bytes 



]ava 



|pirectory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net \espeak\se 
rvices\management\policymanager\servlet\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



110 Entries 
8 9 Repository 
4 6 Root 
846 Template 
1,091 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\se 
rvices \management \processmanager 



12/06/00 04:33p 
12/06/00 04:33p 



<DIR> 
<DIR> 
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test 



12/06/00 


04 : 33p 


<DIR> 


CVS 


12/07/99 


04 :26p 




349 Makefile 


iz / U 0/ U U 


U4 : 33p 


<DIR> 


service 


12/06/00 




/HTD v 

<U1K> 


shell 


12/06/00 


04:33p 


<DIR> 


statemonitor 


12/06/00 


04:33p 


<DIR> 


test 


12/06/00 


04:33p 


<DIR> 


util 


12/06/00 


04:33p 


<DIR> 


web 




10 


File (s) 


349 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\se 
rvi ce s \management \pr oces smanager \CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
f2/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
06:21p 
7 



<DIR> 
<DIR> 



File(s) 



48 Entries 
95 Entries. Log 
82 Repository 
4 6 Root 
84 6 Template 
1,117 bytes 



^Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
:=pvices\management\processmanager\service 



l|2/06/00 04:33p 

'12/06/00 04:33p 

12/06/00 04:33p 

fe/07/99 04:26p 

:fe/07/99 04:26p 

12/07/99 04:26p 

;lj2/07/99 04:26p 

S2/07/99 04:26p 

T2/07/99 04:2 6p 

12/07/99 04:26p 
eRegistry. java 

12/07/99 04:26p 

12/07/99 04:26p 

12 File(s) 



<DIR> 
<DIR> 
<DIR> 



CVS 

652 Makefile 
2,226 ProcessManagerException . j ava 
4,4 94 ProcessManager . java 
5, 155 ProcessManagerServicelntf .esidl 
8, 380 ProcessManagerServiceStub. java 
1, 923 ProcessManagerException. esidl 
1, 393 ProcessManagerServicelntfMessag 

5, 155 ProcessManagerServicelntf . java 
10, 069 ProcessManagerService. java 
39,447 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\management\processmanager\service\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 



04 :33p 
04:33p 
06:21p 
06:21p 
06:21p 



<DIR> 
<DIR> 



582 Entries 
90 Repository 
4 6 Root 
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12/16/99 



06:21p 

6 File(s) 



test 

84 6 Template 
1,564 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\management\processmanager\shell 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:2 6p 
7 



<DIR> 
<DIR> 
<DIR> 



File(s) 



CVS 

427 Makefile 
11,963 PMShellService 
24,700 PMShellConsole 

4,103 PMShell.java 

41,193 bytes 



java 
java 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net \espeak\ 
rvices\management\processraanager\shell\CVS 



se 



.12/06/00 

! f!2/06/00 
fe/16/99 
.lfe/16/99 
G/16/99 
fc/16/99 



04:33p 
04 :33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



209 Entries 
88 Repository 
4 6 Root 
84 6 Template 
1,189 bytes 



I Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
pgyices\management\processmanager\statemonitor 



12/06/00 
Sfe/06/00 
fc/07/99 
il2/06/00 
12/07/ 99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04 :33p 
04 :2 6p 
04:33p 
04:26p 
04:2 6p 
04:26p 
04 :26p 



<DIR> 
<DIR> 

<DIR> 



04 
04 
04 
04 



26p 
26p 
26p 
26p 
04:26p 
04:26p 
04:26p 
15 



File(s) 



4,182 CoreConnectionMonitor . java 
CVS 

3,12 9 ESJoblntf . java 
1,868 ES Job. java 
3,731 In JVM Job. java 

641 Makefile 
4,007 MonitorlniFile. java 
5,260 Process Job. java 
3,947 StateMonitorlntf . java 
1,794 StateMonitorException. java 
4,67 9 StateMonitorConfig. java 
3,468 StateMonitor . j ava 
5,362 TaskErrStreamMonitor. java 
42,068 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\ 
rvices\management\processmanager\statemonitor\CVS 



se 
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test 



12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:21p 664 Entries 

12/16/99 06:21p 95 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

6 File (s) 1, 651 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\s 
rvices\management\processmanager\test 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 378 Makefile 

12/07/99 04:26p 176 TEST . ESH 

12/07/99 04:26p 2,416 TestTask. java 

6 File(s) 2,970 bytes 

'£3SS S 

, 

'^Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\s 
^Kvices\management\processmanager\test\CVS 

j.2/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

!fc/16/99 06:21p 143 Entries 

12/16/99 06:21p 87 Repository 

12/16/99 06:21p 46 Root 

;|j2/16/99 06:21p 84 6 Template 

:«j 6 File(s) 1,122 bytes 

; Spirectory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\s 
f;yices\management\processmanager\util 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/07/99 04:26p 3,136 ClientHelper . java 

12/07/99 04:26p 3,815 CommandLine. java 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 3,272 InJVMRunner . j ava 

12/07/99 04:26p 2,979 IOPipe.java 

12/07/99 04:26p 493 Makefile 

12/07/99 04:26p 3,715 SimpleLoader . java 

9 File(s) 17,410 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\s 
rvices\management\processmanager\util\CVS 
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test 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:21p 310 Entries 

12/16/99 06:21p 87 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

6 File(s) 1,289 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\management\processmanager\web 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> CVS 

12/15/99 04:00p 447 Makefile 

12/07/99 04:26p 12,009 PMShellServlet . java 

12/07/99 04:26p 129 servlet .properties 

6 File(s) 12,585 bytes 

^Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\se 
!|!vices\irianagement\processrrLanager\web\CVS 

ife/06/00 04:33p <DIR> 

iJfe/06/00 04:33p <DIR> 

$2/16/99 06:21p 159 Entries 

;fe/16/99 06:21p 86 Repository 

12/16/99 06:21p 46 Root 

J12/16/99 06:21p 846 Template 

6 File(s) 1,137 bytes 

^Pirectory of E: \e-speak-src_991217\platf orm\ES\src\ java\net \espeak\se 
Ibices \management\servicemanager 



CVS 

848 Makefile 

9, 820 ServiceManager . java 

3,322 ServicelnstanceManager . java 

9, 858 ServiceEventHandler . java 

2, 093 ServicelnstanceManagerFailure. j 

2, 142 ServiceControllerFailure. java 

2,082 ServiceEventHandlerFailure . j ava 

7, 351 ServiceController . java 

2, 289 ServiceManagerlntf . esidl 

5,0 91 ServiceManager Stub . java 

1, 273 ServiceManagerlntfMessageRegist 



12/06/00 


04:33p 


<DIR> 


12/06/00 


04:33p 


<DIR> 


12/06/00 


04:33p 


<DIR> 


12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04 :26p 




12/07/99 


04:26p 




ava 






12/07/99 


04:26p 




12/07/99 


04 :26p 




12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04:26p 
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test 

ry . java 

12/07/99 04:26p 2,318 ServiceManagerlntf . j ava 

12/07/99 04:26p 2,714 ServiceManagerlmpl . java 

12/06/00 04:33p <DIR> ui 

17 File(s) 51,201 bytes 

Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvices\management\servicemanager\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:21p 809 Entries 

12/16/99 06:21p 12 Entries. Log 

12/16/99 06:21p 82 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

7 File(s) 1,795 bytes 

.^Directory of E : \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\se 
^vices\management\servicemanager\ui 

^2/06/00 
^2/06/00 

ife/07/99 04:26p 1,888 ChangeStateFailed. java 

4,2/06/00 04:33p <DIR> CVS 

12/15/99 04:00p 842 Makefile 

12/07/99 04:26p 2,036 ModelException. java 

1,2/07/99 04:26p 6, 867 ServiceManagerUI . java 



04:33p 


<DIR> 


04:33p 


<DIR> 


04:26p 




04:33p 


<DIR> 


04 : OOp 




04 :26p 




04:26p 




04:26p 




04:26p 




04 :26p 




04:26p 




04 :26p 




04:2 6p 




13 File(s) 





ffitVniil S'l * 3 ' 470 Servi ceManagerTableModel.java 

m n V fn 04:26p 15, 099 ServiceManagerServlet . j ava 

J2/07/99 04:26p 21,904 ServiceManagerModel . j ava 

g/07/99 04:26 P 193 servlet . properties 

fi " °1 : "P 8, 894 UiServiceManagerAdapter.java 

12/07/99 04:26c 6,577 UiServiceManager . java 

67,770 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
rvxces\management\serviceraanager\ui\CVS 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/16/99 06:21p 589 Entries 

12/16/99 06:21p 85 Repository 

12/16/99 06:21p 46 Root 

12/16/99 06:21p 846 Template 

6 File(s) 1,566 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\se 
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r vi ces \management \web 



test 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
4 File(s) 



CVS 

servlets 
0 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\se 
rvices\management \web\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
06:21p 
7 



<DIR> 
<DIR> 



File(s) 



3 Entries 
18 Entries. Log 
71 Repository 
4 6 Root 
84 6 Template 
984 bytes 



Ijpirectory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\se 
,£|/i ces \management\web\ servlets 



12/06/00 
i2/06/00 
12/07/99 
12/06/00 
12/15/99 
12/07/99 



04:33p 
04:33p 
04:26p 
04:33p 
04:00p 
04:26p 
6 



<DIR> 
<DIR> 

<DIR> 



File(s) 



7,457 CoreServlet . java 
CVS 

461 Makefile 
10,758 ManagementServlet . java 
18,676 bytes 



^Directory of E: \e-speak-src_991217\platf orm\ES\src\ j ava\net\espeak\se 
wices\management\web\servlets\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



160 Entries 
80 Repository 
4 6 Root 
84 6 Template 
1,132 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\se 
rvices\tunnel 



12/06/00 04:33p 
12/06/00 04:33p 
12/07/99 04:26p 



<DIR> 
<DIR> 



6,943 AbstractSocket . java 
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4- 


1 9 /CM / QQ 
JL Z / U / / y y 


u ^ . z op 


X 


i o / n 7 / QQ 
±Z / V f / yy 


U4 . z op 


9 
Z 


1 0 / Pl7 / Q Q 


A /! • 9 £r\ 

u f± . z op 


1 

J. 


iz / u / / y y 


A /I . 9 

U4 . Z op 


9 
Z 


iZ / U / / yy 


u *± . z op 


9 
Z 


1 9 / fl 7 / QQ 

IZ / u / / y y 


Oh I 2 op 




1 9 / H7 / QQ 
_LZ / U / / y y 


H/1 • 9 
U4 . Z Op 


9 

z 


1 9 / n^ / on 

_LZ / uO/ Uu 


A A • 9 Qv-, /HTDs 

. OOp \U1K/ 




i o / m / QQ 

iz / u / / y y 


Oh I 2 bp 


b 


19 / O 7 / QQ 

iz / o / / y y 


A / . 9 . 

04 : Zbp 


9 


12/0 / / y y 


04 : z op 


0 
2 


iz/U / / yy 


0 4 : zop 


1 


12/07/99 


04 : z op 


z 


*io / a "7 / q q 

iz / o / / y y 


04 : 2 bp 


4 


12/ 01/33 


04 : zbp 




1 9 / C\H / Q G 

iz/ u / / y y 


A / » 9 a>-^ 

04 : Zop 


9 


1 9 / n 7 / QQ 

iz / u / / y y 


U4 : Z bp 


9 


1 O / A "7 / QQ 

lz / 0 I / yy 


04 : z bp 


r- 
O 


1 o / n 7 / QQ 

; 4 z / u / / y y 


A ^ . 9 £ — 

Oh I 2 bp 


-1 
1 


*bs*iS o / r\H / Q Q 

.xz/u //yy 


04 : Zop 




! % ? 9 / A'7 /no 

^-tz/u / /yy 


0 4 : zbp 




¥o /m / Q Q 

i^z/u / /yy 


0 4 : z bp 


2 


o / a i / q q 

p|bZ / u / / y y 


04 : 2 bp 


1 


' ¥ 9 / a *7 / Q Q 

r||Z/ u / / y y 


A /I • 9 

04 : zbp 




To / n 7 / Q Q 

!^|Z/ u / / y y 


A A . 9 

U4 . Z Op 




? ¥9 / n 7 / q q 
;jiZ / u / / y y 


u 4 : z bp 


1 


1 ^ 0 / a 9 /QQ 

:s i z / u / / y y 


A A • 9 £Tw 

0 4 : 2 bp 


2 


1 O / A "7 / QQ 

j ji.z / 0 / / y y 


0 4 : Zbp 


2 


1 0 / m / qq 

iinZ / u / / y y 


04 : 2 bp 


1 


-Tl.O /AH / A A 

i||2 / 0 / / 9 9 


U 4 : z 6p 


1 


'it- 9 / n 7 / q a 

j±iZ / u / / yy 


U 4 : z bp 


1 


^-9 /m / Q Q 

ribz / u / / y y 


U4 : zop 




12/07/99 


04:26p 


4 


12/07/99 


04:26p 


2 


12/07/99 


04:26p 


6 


12/07/99 


04:26p 


7 




39 File(s) 


10 



est 

,8 94 AcceptedSocket . java 

,219 ByteArray . java 

,781 ClientSocketFactorylF. java 

,525 CI ient Socket Factory . java 

,428 ClientSocket . java 

700 compile.bat 
,227 ConnectTunnelClientlF. java 
CVS 

,227 Dialog. java 

,218 ESClientSocketFactoryStub .java 
, 984 ESClientSocketFactorySkel .java 
, 777 ESClientSocketFactorylF. java 
, 203 ESConnectTunnelClientlF. java 
,777 ESConnectionFinder . java 

245 esdriver 
, 531 ESDriver . j ava 
,970 ESSocketStub. java 
,860 ESSocketSkel . java 
,861 ESSocketlF. java 
,210 ESTunnelServiceStub. java 
,413 ESTunnelServiceSkel. java 
,802 ESTunnelServicelF. java 
,114 Makefile 

0 Makefile. dep 

518 makefile . release 
,724 ModellF.java 
, 789 PassiveSocket . java 
,195 SimpleConnectionFinder . java 
,674 SocketRegistrylF. java 
, 68 6 SocketlnternlF. java 
,788 SocketlF. java 

252 tscrrid 
,534 TSCmd.java 
, 782 TunnelServicelF. java 
, 878 TunnelService . java 
,590 TunnelAttributes . java 
6,319 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\se 
rvices\tunnel\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File(s) 



2,001 Entries 
63 Repository 
4 6 Root 
84 6 Template 
2,956 bytes 
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test 



Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\ut 
il 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/07/99 04:26p 6,191 Assert. java 

12/07/99 04:26p 2,023 Codecoverage . java 

12/07/99 04:26p 2,289 CoverageThread. java 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 3,729 ErrorMsg . j ava 

12/07/99 04:26p 15,301 ESAbstractWriter . java 

12/07/99 04:26p 9,088 ESArray.java 

12/07/99 04:26p 2,605 ESContainer . java 

12/07/99 04:26p 26,220 ESDebug.java 

12/07/99 04:26p 5,855 ESFileWriter . java 

12/06/00 04:33p <DIR> esidl 

12/07/99 04:26p 6,271 ESList.java 

12/07/99 04:26p 3,817 ESLogStream. java 

;|2/07/99 04:26p 2, 997 ESMapNode . java 

;lp/07/99 04:26p 16,204 ESMap.java 

K/07/99 04:26p 2, 747 ESPrintWriter . java 

$2/07/99 04:26p 4,619 ESSet.java 

Hp/07/99 04:26p 6,346 ESString . j ava 

J2/07/99 04:26p 10,178 ESStrings . j ava 

22/07/99 04:26p 17,634 ESText.java 

12/07/99 04:26p 14,600 ESTracer . java 

12/07/99 04:26p 2,099 ExternalLogger . java 

,12/07/99 04:26p 6,221 FileServerServlet . j ava 

12/07/99 04:26p 7,029 GenericListenerList . j ava 

12/07/99 04:26p 19,890 IniFile.java 

12/06/00 04:33p <DIR> io 

|j>/15/99 04:00p 1,400 Makefile 

£2/06/00 04:33p <DIR> misc 

12/07/99 04:26p 4,161 NullPrintStream. j ava 

12/07/99 04:26p 4,350 Poll. java 

12/07/99 04:26p 50,112 SysLoader . j ava 

12/07/99 04:26p 6,639 TasklnJVM. j ava 

12/07/99 04:26p 3,646 TaskLoader . java 

12/07/99 04:26p 8,240 TaskNew JVM. java 

12/07/99 04:26p 6,598 TaskRemote . j ava 

12/07/99 04:26p 7,785 TaskReader . j ava 

12/07/99 04:26p 4,939 TaskServer . j ava 

12/07/99 04:26p 3,170 TaskWatcher . j ava 

12/07/99 04:26p 32,665 Task. java 

12/07/99 04:26p 3,430 TestHelper . java 

12/07/99 04:26p 6,416 Trace. java 

12/06/00 04:33p <DIR> ts 
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12/06/00 


04:33p 




<DIR> 


12/07/99 


04:26p 








46 


File (s) 


Directory of E : ' 


Ve- 




il\CVS 






12/06/00 


04:33p 




<DIR> 


12/06/00 


04:33p 




<DIR> 


12/16/99 


06:21p 






12/16/99 


06:21p 






12/16/99 


06:21p 






12/16/99 


06:21p 






12/16/99 


06:21p 








7 


File(s) 


Directory of E:\e- 


•speak-src ! 


il\esidl 








±2/06/00 


04:33p 




<DIR> 


ifc/06/00 


04:33p 




<DIR> 


,ij2/07/99 


04:26p 






11=2/06/00 


04:33p 




<DIR> 


|2/07/99 


04:26p 






12/07/99 


04 :2 6p 






ife/07/99 


04:26p 






12/07/99 


04 :26p 






;12/07/99 


04:26p 






12/07/99 


04:26p 






1=2/07/99 


04:26p 






Ik/07/99 


04:26p 






lfe/07/99 


04:26p 






g/07/99 


04:26p 






12/07/99 


04 :2 6p 








15 


File (s) 



test 

tsutil 
6,296 UniquelD. java 
343,800 bytes 



1,957 Entries 

69 Entries. Log 
52 Repository 
4 6 Root 
84 6 Template 
2,970 bytes 



11,106 CodeGen. java 
CVS 

32,28 6 IDLCompiler . java 

13,857 IDLTypeRepository. java 
3, 997 ImportedTypeRepository. java 
2, 391 InvalidlDLTypeException. java 
593 Makefile 

20,659 Marshaller . java 
3,320 MyPrintWriter. java 
7,153 PrimitiveTypeMap. java 

18,662 StubCompiler . java 

18,593 TypeValidator. java 

14,618 Utils.java 

147,235 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\ut 
il\esidl\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File(s) 



659 Entries 
58 Repository 
4 6 Root 
84 6 Template 



1,609 bytes 

Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\ut 
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test 

il\io 



12/06/00 


0 4 : 3 3p 


<DIR> 


12/06/00 


04 : 33p 


<DIR> 


12/06/00 


04:33p 


<DIR> 


12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04:26p 




12/07/99 


04 :26p 




12/07/99 


04:26p 




12/07/99 


04:26p 





10 File(s) 



CVS 

5,283 FileOutputStreara. java 

4,154 LogContext . java 

8,302 LogEnv.java 

7,550 Logger. java 

4,571 LogOutputStream. java 

455 Makefile 
3,029 NullOutputStream. java 
33,344 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\ut 
il\io\CVS 



12/06/00 


04 


: 33p 


.12/06/00 


04 


: 33p 


42/16/99 


06 


:21p 


!f 2/16/99 


06 


:21p 


^2/16/99 


06 


:21p 


$2/16/99 


06 


:21p 
6 


: "Directory of E: 


il\misc 






312/06/00 


04 


: 33p 


:fe/06/oo 


04 


: 33p 


;3?2/07/99 


04 


:26p 


$2/07/99 


04 


: 2 6p 


:fe/07/99 


04 


: 26p 


'12/07/99 


04 


:26p 


12/06/00 


04 


: 33p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 



<DIR> 
<DIR> 

369 Entries 
55 Repository 
4 6 Root 

846 Template 
File(s) 1,316 bytes 



<DIR> 
<DIR> 

2,422 Array. java 
12 , 4 60 ByteArray. java 

4,536 ByteBuf f er . java 
10,566 Cons. java 
<DIR> CVS 

429 Makefile 
5,38 7 Queue. java 
2,042 Testable. java 
10 File(s) 37,842 bytes 



Directory of E : \e-speak-src__991217 \platf orm\ES\src\ j ava\net\espeak\ut 
il\misc\CVS 



12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:21p 

12/16/99 06:21p 

12/16/99 06:21p 



<DIR> 
<DIR> 

341 Entries 
57 Repository 
4 6 Root 
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12/16/99 06:21p 

6 File(s) 



test 

846 Template 
1,290 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\ut 



il\ts 














04 


• 3 3r> 


^ U 1. ~\/ 






1 ? /ofi/oo 


04 


- ^n 








12 /06/00 


04 


• *j ^ 






u v o 


1 9 /07 /QQ 


04 


• 2 fin 




7^1 
/ o X 


1 J aJ\Ci. J Lc 


1 9 /07 /QQ 


0 4 


• 9 fin 

• z op 




^ r 9 n 


O V* /S A — f~ * T V~ 1 V>l -j — ?V/T — \ -i^i — s V* ~» TT 

r re u Lyr rxn LiYianager . ]ava 


1 9 /m / QQ 


O 4 


• 9 f>r\ 

m Z Dp 






I OiiLOlLLxC . J dVd 


19/07/QQ 


04 


* 2 fin 




R ^OR 




19/07 /QQ 

-LZ / U / / _7_? 


04 


• 9 fin 
■ c. up 




9 & £7 
Z , o O / 


loUdLerr . javd 


1 9 / 07 / Q Q 


0 4 


. z op 




9 7 £ /I 
Z , / 04 


i o ueiauitr ac tiory . 3<^va 


1 9 / n 7 / QQ 




. z op 






TSFactory . java 


1 9/07 /QQ 


04 


• 9 fin 

• z op 




in 7 m 

/Ox 




1 9 /m /QQ 
x z / u / / :? :? 


C\A 
V H 


. z op 




1 p 1 /I "3 


i bLisr , ] ava 


1 9 /07 /QQ 


04 


• 2 fin 

* z. up 




9 P9Q 
z , o z ;? 


i DHapiijnuiuera uion . ] ava 


31? / 0 7 / Q Q 


04 


* 9 fin 




28,181 


TSMap. java 


: #2/07/99 


04 


:2 6p 




3,044 


TSObservable . j ava 


&/07/99 


04 


:26p 




22, 612 


TSParser . java 


S2/07/99 


04 


:2 6p 




2,237 


TSParseException. java 


j |fe/07/99 


04 


:26p 




2, 488 


TSPrettyPrinter . java 


12/07/99 


04 


:2 6p 




6,701 


TSTest. java 


$2/07/99 


04 


:26p 




30,139 


TSUtils. java 


12/07/99 


04 


:26p 




8, 179 


TSValue. java 


12/07/99 


04 


:26p 




3,771 


TSVisitor . java 


; | r 2/C7/99 


04 


:2 6p 




2,520 


TypeErrorException . j ava 


1 II 




23 


File (s) 


209,817 bytes 



'{^Directory of E : \e- speak- src_9 912 17 \platform\ES\src\java\net\espeak\ut 
i|i\ts\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File(s) 



1,048 Entries 
55 Repository 
4 6 Root 
846 Template 
1,995 bytes 



Directory of E: \e- speak- src_9 9 1217 \platform\ES\src\ java \net\espeak\ut 
il\tsutil 



12/06/00 04:33p 
12/06/00 04:33p 
12/06/00 04:33p 



<DIR> 
<DIR> 
<DIR> 



CVS 
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test 



12/07/99 


04 


:26p 


4, 605 


List . i ava 


12/07 /99 


04 


: 26p 


4 98 


k" a "F "i 1 

liU JVC1 J L *3 


12/07 /99 


04 


: 26p 


4, 889 


Man i ava 


12/07 /99 


04 


• ?6r> 


11/ J_ o 


C \/Ti lavs 


12/07/99 


04 


:2 6p 


2, 545 


TSBinary . j ava 


12/07/99 


04 


:2 6p 


2, 335 


TSBoolean. java 


12/07/99 


04 


:26p 


2,342 


TSInteger . java 


12/07/99 


04 


:26p 


2,310 


TSNumber . java 


12/07/99 


04 


:26p 


2,225 


TSString. java 


12/07/99 


04 


:2 6p 


2, 165 


TSTag. java 


12/07/99 


04 


:2 6p 


2, 426 


TSToken. java 



14 File(s) 37,499 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\ut 
il\tsutil\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
Jfe/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



532 Entries 
59 Repository 
46 Root 

84 6 Template 
1,483 bytes 



directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\we 
mccess 



12/06/00 


04:33p 


<DIR> 




12/06/00 


04:33p 


<DIR> 




fe/06/00 


04:33p 


<DIR> 




Jfe/07/99 


04:26p 




3,264 


ife/07/99 


04:26p 




2, 913 


ft/06/00 


04:33p 


<DIR> 




T2/07/99 


04:26p 




3, 765 


12/07/99 


04:26p 




15, 409 


12/07/99 


04:26p 




10, 988 


12/07/99 


04:26p 




11,250 


12/07/99 


04:26p 




2,067 


12/07/99 


04:26p 




5,440 


12/07/99 


04:26p 




4, 423 


12/07/99 


04:26p 




4, 589 


12/07/99 


04:26p 




3,703 


12/07/99 


04:26p 




6,801 


12/06/00 


04:33p 


<DIR> 




12/07/99 


04:26p 




4, 429 


12/15/99 


04 : OOp 




1,385 


12/07/99 


04:26p 




634 


12/07/99 


04:26p 




3,165 



conf 

Converterlntf . java 
Convert erlnf o. java 
CVS 

DispatchTable . j ava 
ESConverter . j ava 
ESForinMapper . j ava 
ESMapper . java 
ESMessageXml . j ava 
ESProcessor . java 
FormGenericMapper . j ava 
FormLoginMapper . java 
GenericMapper . j ava 
GenericConverter . java 
htdocs 

Mailbox. java 
Makefile 

makefile. release 
Mapperlnf o . j ava 
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LcSL 




i o / on / o q 

IZ / U / / y y 


n /i 

U 4 


. z op 


0 C.7 ^ 
Z , O / O 


rJappeiinuI . Java 


io / m / QQ 
±z / u / / y y 


U 4 


. Z op 


o n a Pi 

Z , U 4 u 


D V* ^ O C 1 V T T"l "f~ "F ~1 —\ TT — 1 

Jr I70C6S S OJT ID. L X . Javd 


1 o /m / QQ 
IZ / V t / yy 


U 4 


. z op 


9 71 £ 
Z / / ID 


rlUUcobUI IIILU . Java 


1 o /m /QQ 
±z / u / / y y 


U ft 


. z op 


"3 ££7 
J f DO / 




1 o / m / QQ 
IZ/ U / / y y 


n /i 

U4 


. Z Dp 


9 9^7 
Z / Z 3 / 


KequesLDdutNcquesi . j avd 


1 o /m / on 

iz/ u / / y y 


U4 


: Z bp 


O OQQ 

Z , Zo o 


RequestNot Found . j avs 


i o / q 7 / qq 

iz / u / / y y 


U4 


: z bp 


9 9 £ £^ 

z f z bo 




1 o / q 7 /QQ 

iz/ u / / y y 


Q /I 

U4 


: z bp 


O O C 7 

Z f z b / 


RequestMult ipleChoice . j ava 


1 o /m /QQ 

iz / u / / y y 


Q A 


: Z bp 


9 9/11 

Z f z 4 1 


Keques tc orDiaoen . ] ava 


lz/u / / y y 


Q /I 

(J4 


: Zbp 


/j ore 
4 , o OO 


ServiceDaemon . j ava 


12/07/99 


04 


: 2 bp 


VI "7 ~7 A 

4,779 


ServiceTranslator . j ava 


-i o f C\H / QQ 

12/07/99 


Q A 

U4 


• O 

: Z op 


O ICC 

o f loo 


ServiceTable . j ava 


12/07/99 


04 


: z bp 


•"7 q n o 

/ , y yz 


ServiceHanciler . j ava 


TO / C\1 / QQ 

lz/u / /yy 


U4 


: Z bp 


lb f ooo 


ServiceDispatcher . j ava 


1 O f f\H / QQ 

lz/u / / y y 


a /t 
U4 


: Z bp 


C Q O Q 

o , yzy 


SessionTable . j ava 


lz/o / / y y 


U4 


: z bp 


O Q 1 1 

z f y / 1 


Session . j ava 


1 o / n 7 / QQ 
1Z/U 1 1 yy 


n a 

U4 


* z op 


"5 7 9 9 


1 ransiauioni aDie . j ava 


12/07/99 


04 


; 2 bp 


5,250 


URLBinder . j ava 


1 o / r\*i /QQ 

J.2/07/99 


Q /I 

04 


: zop 


o , 4oo 


URLCache . j ava 


itz/u //yy 


U4 


: Z bp 


/ f o4 3 


URLConverter . j ava 


4 5 2/07/99 


04 


:26p 


6,889 


Util . java 


lfc/07/99 


04 


:26p 


2, 663 


WAExceptionlnf 0 .java 


! i!2/07/99 


04 


:26p 


2,472 


WANameList . j ava 


fe/07/99 


04 


:26p 


6,942 


WebAccess . j ava 


!lfe/07/99 


04 


:26p 


9,263 


XMLApp3 .java 



46 File(s) 



201,632 bytes 



'I directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\we 
|access\conf 



12/06/00 04:33p <DIR> 

12/06/00 04 :33p <DIR> 

^2/06/00 04:33p <DIR> 
^2/07/99 04:26p 

12/06/00 04:33p <DIR> 

5 File(s) 



CVS 

27,318 httpd.conf 
j serv 
27,318 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\we 
baccess\conf \CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
06:21p 

7 File(s) 



<DIR> 
<DIR> 



50 Entries 
15 Entries. Log 
62 Repository 
4 6 Root 
846 Template 
1,019 bytes 
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test 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\we 
baccess\conf \ j serv 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 
04:26p 

6 File(s) 



<DIR> 
<DIR> 
<DIR> 



CVS 

6,559 jserv.conf 
12,790 j serv. properties 
6,496 zone. properties 
25, 845 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\we 
baccess\conf \ jserv\CVS 



12/06/00 
12/06/00 
12/16/99 
.12/16/99 
12/16/99 
&/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
6 



<DIR> 
<DIR> 



File (s) 



155 Entries 
68 Repository 
4 6 Root 

846 Template 
1,115 bytes 



^Directory of E: \e-speak-src_991217\platf orm\ES\src\java\net\espeak\we 
:$.access\CVS 



'12/06/00 
,3,2/06/00 
12/16/99 
;ife/16/99 
12/16/99 
Sfe/16/99 
$1/16/99 



04:33p 
04:33p 
06:21p 
06:21p 
06:21p 
06:21p 
06:21p 
7 



<DIR> 
<DIR> 



File(s) 



2,218 Entries 

30 Entries. Log 
57 Repository 
46 Root 
84 6 Template 
3,197 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\we 



baccess\htdocs 


12/06/00 


04 


: 33p 


12/06/00 


04 


:33p 


12/07/99 


04 


: 2 6p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/06/00 


04 


:33p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 



<DIR> 
<DIR> 



<DIR> 



11, 



1,454 
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699 ask-lu-vocab.html 
703 ask-reg-vocab . html 
665 book-buying . html 
509 button-back-to-register.gif 
CVS 

638 ESPEAK.jpg 
88 6 green-ball . gif 
index . html 



12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 



04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:33p 
04:2 6p 
04:26p 

19 File(s) 



<DIR> 



test 

1,107 login-reply.html 
1,102 logo.gif 
1,265 lookup-form.html 
691,318 maylOic.bmp 
41,279 maylOic.jpg 
1,522 register-form.html 
servlets 
148,992 web-espeak_slides.ppt 
5,34 6 welcomenew.gif 
908,485 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\ java\net\espeak\we 
baccess\htdocs\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
.12/16/99 
$2/16/99 
i§2/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:21p 
06:21p 
06:21p 

7 File(s) 



<DIR> 
<DIR> 



785 Entries 
18 Entries. Log 
64 Repository 
4 6 Root 

84 6 Template 
1,759 bytes 



|Directory of E: \e-speak-src_991217\platform\ES\src\java\net\espeak\we 
,baccess\htdocs\servlets 



12/06/00 
1,2/06/00 
3*2/07/99 
:E2/06/00 
&/07/99 
'fe/07/99 
ilfe/07/99 
12/15/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 


<DIR> 


04:33p 


<DIR> 


04 :26p 




04:33p 


<DIR> 


04:26p 




04:2 6p 




04 :26p 




04:00p 




04:26p 




04:2 6p 




04:26p 




04 :26p 




04:26p 




04:26p 




14 


File(s) 



20,614 BookBroker. java 
CVS 

7,045 Forms. java 

6,64 5 HTML2XML . j ava 

4,089 IsItWorking. java 
575 Makefile 
4 0 proxy. cfg 
10,518 ProxyBarnes . j ava 
12,489 ProxyFatBrain. java 

3,57 8 Proxylnfo. java 

5,4 67 ShowRegistrationForm. java 

2,224 XMLDocTags. java 

73,284 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\java\net\espeak\we 
baccess\htdocs\servlets\CVS 



12/06/00 04:33p 
12/06/00 04:33p 
12/16/99 06:22p 



<DIR> 
<DIR> 



569 Entries 
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12/16/99 
12/16/99 
12/16/99 



06:22p 
06:22p 
06:22p 

6 File(s) 



test 

73 Repository 
4 6 Root 
84 6 Template 
1,534 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\perl 



12/06/00 
12/06/00 
12/06/00 
12/06/00 



04 :33p 
04:33p 
04:33p 
04:33p 

4 



<DIR> 
<DIR> 
<DIR> 
<DIR> 



File (s) 



CVS 
plesi 
0 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\perl\CVS 



12/06/00 
12/06/00 
12/16/99 
.12/16/99 
•#2/16/99 
$2/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
06:22p 

7 File(s) 



<DIR> 
<DIR> 



3 Entries 
15 Entries. Log 
36 Repository 
4 6 Root 
84 6 Template 
94 6 bytes 



^Directory of E:\e-speak-src_991217\platform\ES\src\perl\plesi 



12/06/00 
12/06/00 
'12/07/99 
£2/07/99 
1^2/07/99 
'fe/06/00 
;lf2/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04 :26p 
04:33p 
04:26p 
04:26p 
04:26p 
04 :26p 
04:26p 
04:2 6p 
04:2 6p 
04:26p 
04 :26p 
04:26p 
04:2 6p 

17 File(s) 



<DIR> 
<DIR> 



<DIR> 



9,832 
10,309 
2,220 

18,584 

13,760 
8, 467 
7, 139 
7, 051 

15,799 
2, 636 
4,849 
2, 019 
2,701 
3,179 

108,545 



ABI . pm 
abi2c.pl 
abi2txt .pi 
CVS 

ESLib.pm 
ESReader .pm 
ESUtil.pm 
ESWriter .pm 
logexpand. pi 
README . txt 
rtc.pl 
rts .pi 
sigbytes .pi 
tc.pl 
ts .pi 
bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\perl\plesi\CVS 
12/06/00 04:33p <DIR> 
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12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
6 



<DIR> 



File(s) 



test 

639 Entries 
42 Repository 
4 6 Root 

84 6 Template 
1,573 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\python 



12/06/00 
12/06/00 
12/06/00 
12/06/00 



04:33p 
04:33p 
04:33p 
04:33p 
4 



File(s) 



<DIR> 
<DIR> 
<DIR> 
<DIR> 



CVS 
pyesi 
0 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\python\CVS 



12/06/00 
,3,2/06/00 
112/16/99 
;S!2/16/99 
l!2/16/99 
&2/16/99 
if2/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
06:22p 

7 File(s) 



<DIR> 
<DIR> 



3 Entries 
15 Entries. Log 
38 Repository 
4 6 Root 
84 6 Template 
948 bytes 



f Directory of E:\e-speak-src_991217\platform\ES\src\python\pyesi 



12/0 6/00 
fe/06/00 
lfe/06/00 
Jfe/06/00 
lfe/06/00 
1*2/06/00 
12/07/99 
12/06/00 
12/07/99 



04 :33p 
04 :33p 
04:33p 
04:33p 
04 :33p 
04:33p 
04:26p 
04:33p 
04 :26p 
9 



<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 
<DIR> 

<DIR> 



File(s) 



abi 
CVS 
io 
net 

25,590 README . txt 
util 

0 init .py 

25,590 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\python\pyesi\abi 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
12/07/99 



04:33p 
04:33p 
04:26p 
04:26p 
04:26p 
04:33p 
04:26p 



<DIR> 
<DIR> 



<DIR> 



17,585 abi.py 

2,480 abi2txt.py 
48,218 abiobj.py 
CVS 

18,088 eslib.py 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04 :26p 
04:26p 
04:26p 
04:26p 
04 :26p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04:2 6p 
04:26p 
04:26p 

20 File(s; 



<DIR> 



test 
6,762 
2,476 
9, 925 
11,082 
10,554 
7,026 

5, 049 
10, 667 
2, 168 
5,455 
7, 777 
0 

165,312 



esobj . py 
esutil .py 

es_input_s tream . py 

es_output_stream . py 

genabi .py 

genobj .py 

msg 

rtc.py 

rts . py 

sigbytes .py 

tc.py 

ts .py 

_init .py 

bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\python\pyesi\abi\C 



VS 

12/06/00 
12/06/00 
12/16/99 
lfe/16/99 
42/16/99 
: ij2/16/99 
t'2/16/99 



04 :33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
06:22p 



<DIR> 
<DIR> 



7 File(s; 



744 Entries 
13 Entries. Log 

48 Repository 
4 6 Root 
84 6 Template 
1, 697 bytes 



[Directory of E:\e-speak-src_991217\platform\ES\src\python\pyesi\abi\ 



m 



1:2/06/00 

12/06/00 

El/06/00 

1*2/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 



04:33p 

04:33p 

04:33p 

04 :26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 



<DIR> 

<DIR> 
<DIR> 



CVS 

8 msgOOOl.ser 
117 msg0002.ser 
154 msg0003.ser 

53 msg0004.ser 
159 msg0005.ser 

53 msg0006.ser 
194 msg0007.ser 

53 msg0008.ser 
151 msg0009.ser 

53 msgOOlO. ser 
353 msgOOll.ser 

53 msg0012.ser 
275 msg0013.ser 

53 msg0014.ser 
8 msg0015.ser 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
,12/07/99 
!lf2/07/99 
3-2/07/99 
412/07/99 
'$2/07/99 
4J2/07/99 
;i!2/07/99 
ifr/07/99 
12/07/99 
12/07/99 
ii2/07/99 
lfe/07/99 
Jfe/07/99 
Sfe/07/99 
■Ik/07/99 
T'2/07/99 
12/07/99 
12/07/99 
12/07/99 



04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04:26p 

04 :2 6p 

04:26p 

04:2 6p 

04:2 6p 

04 :26p 

04:26p 

04:26p 

04:2 6p 

04:26p 

04:26p 

04:26p 

04:26p 

04 :26p 

04 :26p 

04:26p 

04:2 6p 
04 :26p 
04:26p 
04:26p 
04:2 6p 
04 :26p 
04:26p 
04 :26p 
04:2 6p 
04:2 6p 
04 :26p 
04 :26p 
04 :26p 
04:26p 
04:26p 
04:26p 

55 File(s) 



test 

117 msg0016.ser 
154 msg0017.ser 
53 msg0018.ser 
159 msg0019.ser 

53 msg0020.ser 
136 msg0021.ser 

54 msg0022.ser 
92 msg0023.ser 
54 msg0024.ser 

157 msg0025. ser 

53 msg0026.ser 

91 msg0027.ser 
57 msg0028.ser 
71 msg0029.ser 

54 msg0030.ser 
71 msg0031.ser 
54 msg0032.ser 
86 msg0033.ser 
54 msg0034 . ser 

156 msg0035 . ser 
54 msg0036.ser 

92 msg0037.ser 
54 msg0038.ser 

157 msg0039.ser 

53 msg0040.ser 
91 msg0041.ser 
57 msg0042.ser 
71 msg0043.ser 

54 msg0044.ser 
71 msg0045.ser 
54 msg0046.ser 
86 msg0047 . ser 
54 msg0048.ser 

121 msg0049.ser 
145 msg0050.ser 
75 msg0051.ser 

93 msg0052.ser 
4,895 bytes 



sg\^VS t0ry ° f E:Xe ~ Speak - src - 991217X P latform \ ES \ s ^\Python\pye S i\abi\m 



12/06/00 04:33p 

12/06/00 04:33p 

12/16/99 06:22p 

12/16/99 06:22p 

12/16/99 06:22p 

12/16/99 06:22p 



<DIR> 
<DIR> 



2,499 Entries 
52 Repository 
4 6 Root 
84 6 Template 
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6 File(s) 



test 
3,443 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\python\pyesi\CVS 



12/06/00 


04:33p <DIR> 




12/06/00 


04:33p <DIR> 




12/16/99 


06:22p 


98 Entries 


12/16/99 


06:22p 


52 Entries. Log 


12/16/99 


06:22p 


44 Repository 


12/16/99 


06:22p 


4 6 Root 


12/16/99 


06:22p 


846 Template 




7 File(s) 


1,086 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\src\python\pyesi\io 



±Z / U o/ UU 


n a • q 9>-v 
U4 I 0 op 


sulK> 




i 9 / n £ / nn 
±Z / U o/ UU 


n A • T5n 


/nTD\ 




i o /n7 / qq 
±z / u / / y y 


U4 . Z op 




C ICQ 
O r /DO 


1 o / m / no 

j. z / u / / y y 


U4 : Z op 




O O O £T 

J> , Jz O 


i-alo / n 7 / QQ 

-jz / u / / y y 


u 4 . z op 




9 CQ1 

z , oy 1 


! "Mo /n*7 / QQ 

-d^z / u / / y y 


U 4 : Z op 




O ICO 

z f / oz 


^•o / n £ / n n 
, -£Z / Uo/UU 


n /1 * "5 9>-\ 
U4 . J Jp 


/p|TD\ 




,~f;z / u / / y y 


A /i - 9 

u 4 . z op 




7 9 9 c; 
/ / ZZ 3 


/ n 7 / Q Q 

( j^z / u / / y y 


u 4 . z op 




Q 1 9 Q 

y , iz y 


E 4 5 9 /Pi 7 / QQ 

. zlz / u / / y y 


U 4 . Z Op 




R 7 Q 9 

D r i y z 


f 4lo / A 7 / Q Q 

j_Lz / u / / y y 


U 4 . Z Op 




9 £ £ Q 

Z, boo 


! Ts> /07 


U 1 • 6. \J k> 




1 / _/ VJ \J 


.12/07/99 


04:26p 




3,843 


42/07/99 

J2/07/99 


04:26p 




3, 453 


04:26p 




3, 695 


lfe/07/99 


04:26p 




2, 704 


lfe/07/99 


04:26p 




2,678 


:lfe/07/99 


04:26p 




6, 055 


i5/07/99 


04:26p 




4,126 


12/07/99 


04:26p 




4,358 


12/07/99 


04:26p 




3,948 


12/07/99 


04:26p 




4, 315 


12/07/99 


04:26p 




4, 087 


12/07/99 


04:26p 




6,477 


12/07/99 


04:26p 




3,535 


12/07/99 


04:26p 




3,579 


12/07/99 


04 :26p 




4, 494 


12/07/99 


04:26p 




4,713 


12/07/99 


04:26p 




4,239 


12/07/99 


04:26p 




3,466 


12/07/99 


04:26p 




3,646 


12/07/99 


04:26p 




8,115 


12/07/99 


04:26p 




0 



CVS 
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33 File(s) 



test 
130,783 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\python\pyesi\io\CV 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
6 



<DIR> 
<DIR> 



File(s) 



1,724 Entries 
47 Repository 
46 Root 
846 Template 
2,663 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\src\python\pyesi\net 



12/06/00 
12/06/00 
12/07/99 
.12/06/00 
; t2/07/99 
•&/07/99 
£2/07/99 
312/07/99 
:fe/07/99 
12/07/99 
32/07/99 
12/07/99 
4,2/07/99 



04:33p 
04:33p 
04:26p 
04:33p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04 :26p 
04 :26p 
04:26p 
04:26p 
13 



<DIR> 
<DIR> 

<DIR> 



File(s) 



14,763 client_socket .py 
CVS 

9,316 http_client_stream.py 
5,14 8 server_socket .py 
4,848 simple_server .py 
3,626 simple_handler .py 
3,266 socket_output_stream.py 
3,294 socket_input_stream.py 
4,710 threaded_server .py 
2,562 threaded_handler .py 

0 init .py 

51,533 bytes 



jpirectory of E:\e-speak-src_991217\platform\ES\src\python\pyesi\net\C 



T2/0 6/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04 :33p 
04:33p 
06:22p 



<DIR> 
<DIR> 



06: 
06: 
06: 



22p 
22p 
22p 
6 



File (s) 



552 Entries 
48 Repository 
4 6 Root 
84 6 Template 
1,4 92 bytes 



Directory of E:\e-speak-src_991217\platform\ES\src\python\pyesi\util 



12/06/00 
12/06/00 
12/06/00 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:33p 
04:26p 
04:26p 



<DIR> 
<DIR> 
<DIR> 



CVS 

10,033 file_observer .py 
16,433 file_queue.py 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:26p 
04:26p 
04 : 2 6p 
04:26p 
04:26p 

10 File(s) 



test 

8,638 log.py 

3,565 threadjpool.py 

3,039 timestamp.py 

6,417 url.py 

0 init .py 

48,125 bytes 



Directory of E: \e-speak-src_991217\platform\ES\src\python\pyesi\util\ 
CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
6 



<DIR> 
<DIR> 



File (s) 



340 Entries 
4 9 Repository 
4 6 Root 

84 6 Template 
1,281 bytes 



.Directory of E:\e-speak-src_991217\platform\ES\tutorial 



;i!2/o6/oo 

lfe/06/00 

;fe/06/oo 

£2/07/99 
12/06/00 
;l2/06/00 



04:33p 
04:33p 
04:33p 
04:26p 
04:33p 
04:33p 
6 



<DIR> 
<DIR> 
<DIR> 

<DIR> 
<DIR> 



File (s) 



CVS 

225 Makefile 

sharebroker 
usedcarsale 
225 bytes 



^Directory of E: \e-speak-src_991217\platform\ES\tutorial\CVS 



ft/06/00 

£2/06/00 
14/16/99 
tt/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:23p 
06:22p 
06:22p 



<DIR> 
<DIR> 



12/16/99 06:22p 



7 File(s) 



48 Entries 
42 Entries. Log 
36 Repository 
4 6 Root 
84 6 Template 
1,018 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker 



12/06/00 
12/06/00 
12/07/99 
12/06/00 
12/06/00 
12/06/00 
12/07/99 



04:33p 
04:33p 
04:26p 
04:33p 
04:33p 
04:33p 
04:26p 



<DIR> 
<DIR> 

<DIR> 
<DIR> 
<DIR> 



459 compile.bat 
conf ig 
CVS 
doc 

296 Makefile 
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test 

12/07/99 04:26p 2,040 setenv 

12/07/99 04:26p 1,416 setenv.bat 

12/06/00 04:33p <DIR> src 

10 File(s) 4,211 bytes 

Directory of E : \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\c 
onf ig 



12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


:33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 


CVS 


12/06/00 


04 


: 33p 


<DIR> 


example 1 


12/06/00 


04 


:33p 


<DIR> 


example2 


12/06/00 


04 


:33p 


<DIR> 


example3 


12/06/00 


04 


:33p 


<DIR> 


example 4 


12/06/00 


04 


: 33p 


<DIR> 


example 5 






8 


File(s) 


0 bytes 



^Directory of E : \e-speak-src_991217\platform\ES\tutorial\sharebroker\c 
%if ig\CVS 

fe/06/00 04:33p <DIR> 
;|=2/06/00 04:33p <DIR> 

|2/16/99 06:22p 3 Entries 

|2/16/99 06:22p 90 Entries. Log 

;12/16/99 06:22p 55 Repository 

12/16/99 06:22p 46 Root 

12/16/99 06:22p 846 Template 

J 7 File(s) 1,040 bytes 

^Directory of E:\e-speak-src 991217\platf orm\ES\tutorial\sharebroker\c 



Sfif ig\examplel 








.Sis. 

il?2/06/00 


04:33p 


<DIR> 






12/06/00 


04:33p 


<DIR> 






12/07/99 


04 :26p 




20 


bank.pr 


12/07/99 


04:26p 




261 


bankvocab. ini 


12/07/99 


04:26p 




1,247 


BankVocabulary . xml 


12/06/00 


04:33p 


<DIR> 




CVS 


12/07/99 


04:26p 




70 


runbankvocab . bat 


12/07/99 


04:26p 




61 


runbankvocab . sh 


12/07/99 


04 :26p 




110 


runvocabf inder . bat 


12/07/99 


04:26p 




100 


runvocabf inder . sh 



10 File(s) 1,869 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\c 
onf ig\examplel\CVS 
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12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
22p 
22p 
22p 
6 



06 
06 
06 



<DIR> 
<DIR> 



File (s) 



test 



366 Entries 
64 Repository 
4 6 Root 

84 6 Template 
1,322 bytes 



onf ig\example2 


12/06/00 


04 


: 33p 


12/06/00 


04 


: 33p 


12/07/99 


04 


: 2 6p 


12/07/99 


04 


:26p 


12/07/99 


04 


:2 6p 


12/07/99 


04 


:26p 


12/06/00 


04 


:33p 


.1.2/07/99 


04 


: 2 6p 


1:2/07/99 


04 


:26p 


3:2/07/99 


04 


:26p 


ilfe/07/99 


04 


: 2 6p 



11 File(s) 

m 

.ipirectory of E:\e-speak-src 
<Jnf ig\exainple2\CVS 



<DIR> 
<DIR> 

290 bank.ini 

18 bank.pr 

1,322 BankService.xml 

1,247 BankVocabulary.xml 

<DIR> CVS 

65 runbankservice.bat 
90 runbankservice. sh 
107 runclient.bat 
98 runclient.sh 
3,237 bytes 



:_991217\platform\ES\tutorial\sharebroker\c 



42/06/00 
1:2/06/00 
ft/16/99 
jfe/16/99 
12/16/99 
lfe/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 

6 File(s) 



<DIR> 
<DIR> 



407 Entries 
64 Repository 
4 6 Root 
84 6 Template 
1,363 bytes 



onf ig\example3 


12/06/00 


04 


: 33p 


12/06/00 


04 


: 33p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 



<DIR> 
<DIR> 



6 account.dat 
314 addfunds.gif 
1,097 add_share.gif 

18 bank.pr 
1,322 BankService.xml 
1,247 BankVocabulary.xml 
1,091 buy.gif 

131 cancelord.gif 
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12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/06/00 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

12/07/99 

3,2/07/99 

W07/99 

$2/07/99 

$2/07/99 

tt/07/99 

^S/07/99 

&/07/99 

11/07/99 

12/07/99 

12/07/99 

2-2/07/99 



04:26p 
04:2 6p 
04:2 6p 
04 :26p 
04:33p 
04:26p 
04:26p 
04 :26p 
04:26p 
04:26p 
04:2 6p 
04:2 6p 
04 :26p 
04:26p 
04:26p 
04 :26p 
04:2 6p 
04 :26p 
04:26p 
04 :26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:2 6p 
04:26p 
04 :26p 

39 File(s) 



test 

260 change_dir.gif 

254 connect.gif 

330 cpwd.gif 

320 create_vb.gif 
<DIR> CVS 

131 delete.gif 

182 disconnect.gif 

275 download.gif 

110 folder.gif 

174 help.gif 

423 localserver.ini 

300 login.gif 
1,189 open_act.gif 

213 reconnect.gif 
72 runserver.bat 

130 runserver.sh 
1,094 sell.gif 

918 ShareBrokerVocabulary.xml 
1,178 ShareBrokerService.xml 
95 starttrader . sh 
71 stocktrade.bat 
1,170 title.gif 

2 0 trader. pro 
1,335 Trader. xml 

20 traderlntf .pro 
1,253 TraderVocabulary.xml 
1,118 TraderService.xml 

314 upload.gif 

285 watch.gif 
18,460 bytes 



Jirectory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\c 
9=Bfig\example3\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
6 



<DIR> 
<DIR> 



File(s) 



1,787 Entries 
64 Repository 
4 6 Root 
84 6 Template 
2,743 bytes 



Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\c 
onf ig\example4 



12/06/00 04:33p 
12/06/00 04:33p 
12/07/99 04:26p 



<DIR> 
<DIR> 



6 account . dat 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
12/06/00 
12/07/99 
;I'2/07/99 
ft/07/99 
£2/07/99 
#2/07/99 
SS/07/99 
12/07/99 
ft/06/00 
12/07/99 
12/07/99 
12/07/99 
£2/07/99 
ft/07/99 
ife/07/99 



04:26p 
04:2 6p 
04:26p 
04:26p 
04:2 6p 
04:26p 
04:2 6p 
04:2 6p 
04 :26p 
04 :2 6p 
04:33p 
04 :26p 
04:26p 
04:26p 
04:2 6p 
04:2 6p 
04:33p 
04:33p 
04 :26p 
04:26p 
04:26p 
04:26p 
04:26p 
04:2 6p 
04:26p 
04:33p 
04 :26p 
04 :2 6p 
04:26p 
04:26p 
04:26p 
04:2 6p 

35 File(s) 



<DIR> 



<DIR> 
<DIR> 



<DIR> 



test 

314 
1,097 
1, 444 
1,362 
1,091 
131 
260 
254 
330 
320 

131 
182 
275 
110 
174 



300 
1,189 

213 
1, 094 
1, 485 
1, 429 
1,430 

1,170 
1,335 
1,253 
1,118 
314 
285 
20, 096 



addfunds . gif 
add_share.gif 
BankService . xml 
BankVocabulary . xml 
buy. gif 
cancelord. gif 
change_dir . gif 
connect . gif 
cpwd. gif 
create_vb. gif 
CVS 

delete . gif 
disconnect . gif 
download.gif 
folder . gif 
help. gif 
hostl 
host2 
login. gif 
open_act . gif 
reconnect . gif 
sell .gif 

ShareBrokerVocabulary . xml 
ShareBrokerService2 . xml 
ShareBrokerServicel . xml 
singlehost 
title . gif 
Trader. xml 

TraderVocabulary . xml 
TraderService . xml 
upload. gif 
watch. gif 
bytes 



Directory of E: \e-speak-src_991217 \platf orm\ES\tutorial\sharebroker\c 
onf ig\example4 \CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
06:22p 

7 File(s) 



<DIR> 
<DIR> 



1,453 Entries 

50 Entries. Log 
64 Repository 
4 6 Root 
84 6 Template 
2,459 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\c 
onf ig\example4\hostl 
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test 



12/06/00 


04:33p 


<DIR> 


12/06/00 


04:33p 


<DIR> 


12/07/99 


04:26p 




12/07/99 


04:26p 




12/06/00 


04:33p 


<DIR> 


12/07/99 


04:2 6p 




12/07/99 


04:26p 




12/07/99 


04 :26p 




12/07/99 


04 :26p 




12/07/99 


04:26p 




12/07/99 


04 :26p 




12/07/99 


04:26p 





12 File(s) 



Directory of E:\e-speak-src_99 
onfig\example4\hostl\CVS 



141 bank.pr 
22 col 
CVS 

114 runbrokerl.bat 

138 runbrokerl. sh 

7 3 sharebrokerl.bat 
672 sharebrokerl.ini 
304 sharebrokerl . pr 
158 sharebrokerl . sh 

139 stocktrade .pr 
1,761 bytes 

1217\platform\ES\tutorial\sharebroker\ 



:l=2/06/00 04:33p <DIR> 
Ife/06/00 04:33p <DIR> 

C2/16/99 06:22p 448 Entries 

112/16/99 06:22p 70 Repository 

12/16/99 06:22p 46 Root 

jfe/16/99 06:22p 846 Template 

ill 6 File(s) 1,410 bytes 

s Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\ 
jenf ig\example4 \host2 

12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/07/99 04:26p 141 bank.pr 

12/07/99 04:26p 22 co2 

12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 115 runbroker2.bat 

12/07/99 04:26p 137 runbroker2 . sh 

12/07/99 04:26p 73 sharebroker2.bat 

12/07/99 04:26p 730 sharebroker2.ini 

12/07/99 04:26p 302 sharebroker2 . pr 

12/07/99 04:26p 177 sharebroker2 . sh 

12/07/99 04:26p 139 stocktrade . pr 

12 File(s) 1,836 bytes 

Directory of E: \e-speak-src_991217\platform\ES\tutorial\sharebroker\ 
onfig\example4\host2\CVS 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
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12/16/99 
12/16/99 
12/16/99 
12/16/99 



06:22p 
06:22p 
06:22p 
06:22p 

6 File(s) 



test 
448 
70 
46 
846 



Entries 

Repository 

Root 

Template 



1,410 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\ 
onf ig\example4 \singlehost 



12/06/00 


04 


: 33p 


12/06/00 


04 


: 33p 


12/07/99 


04 


: 26p 


12/06/00 


04 


: 33p 


12/07/99 


04 


:26p 


12/07/99 


04 


:2 6p 


12/07/99 


04 


:2 6p 


12/07/99 


04 


: 2 6p 


12/07/99 


04 


: 26p 


,42/07/99 


04 


: 26p 


:i'2/07/99 


04 


:26p 


22/07/99 


04 


:26p 



<DIR> 
<DIR> 

<DIR> 



12 File(s) 



43 bank.pr 

CVS 

549 localserver.ini 
115 runbroker2.bat 
115 runbrokerl.bat 
72 runserver.bat 

206 sharebroker2 .pr 

207 sharebrokerl .pr 
71 stocktrade.bat 
43 stocktrade.pr 

1,421 bytes 



^Directory of E : \e-speak-src_991217 \platf orm\ES\tutorial\sharebroker\ 
ifffif ig\example4\singlehost\CVS 



12/06/00 
42/06/00 
&2/16/99 
1*2/16/99 
12/16/99 
$2/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
6 



<DIR> 
<DIR> 



File (s) 



456 Entries 
75 Repository 
4 6 Root 

84 6 Template 
1,423 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\ 



onf ig\example5 


12/06/00 


04 


: 33p 


12/06/00 


04 


: 33p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:2 6p 



<DIR> 
<DIR> 



6 account.dat 
314 addfunds.gif 
1, 097 add__share.gif 

43 bank.pr 
1,444 BankService.xml 
1, 3 62 BankVocabulary.xml 
1,091 buy.gif 

131 cancelord.gif 
260 change_dir . gif 
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12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:2 6p 


12/06/00 


04 


: 33p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 2 6p 


12/07/99 


04 


: 2 6p 


12/07/99 


04 


: 2 6p 


12/07/99 


04 


: 2 6p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


,12/07/99 


04 


:2 6p 


£2/07/99 


04 


: 2 6p 


E2/07/99 


04 


:26p 


ife/07/99 


04 


:26p 


fe/07/99 


04 


:26p 


•K2/07/99 


04 


:26p 


fe/07/99 


04 


: 2 6p 


;|fe/07/99 


04 


:26p 


12/07/99 


04 


: 26p 


il2/07/99 


04 


:2 6p 


$2/07/99 


04 


:26p 


&/07/99 


04 


: 2 6p 


lfe/07/99 


04 


:26p 


lfe/07/99 


04 


:26p 


12/07/99 


04 


•26p 


T2/07/99 


04 


. 26p 


12/07/99 


04 


2 6p 


12/07/99 


04: 


26p 


12/07/99 


04: 


2 6p 


12/07/99 


04 : 


26p 


12/07/99 


04: 


2 6p 


12/07/99 


04: 


26p 


12/07/99 


04: 


2 6p 


12/07/99 


04: 


2 6p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 


12/07/99 


04: 


26p 



<DIR> 



test 
18 
254 
330 
320 

131 

8, 405 
182 
275 
110 
174 

5, 687 

5, 889 
17,709 
13,800 
13, 686 

9,041 
11, 845 
11,859 
10, 472 
12,712 

9,852 

9, 634 
41, 855 

551 
300 
1,189 
5, 522 
213 
115 
115 
72 

10, 163 
1,094 
72 
206 
20 
1,429 
207 
1, 430 
1,485 
71 
689 
43 
1,170 
43 
1,335 
20 
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cleandb. bat 
connect . gif 
cpwd. gif 
create_vb.gif 
CVS 

delete . gif 
demoexample5 . html 
disconnect . gif 
download.gif 
folder . gif 
help . gif 
Imagel .gif 
Image 10 . gif 
Imagell . gif 
Imagel2.gif 
Imagel3.gif 
Image2 .gif 
Image3 . gif 
Image4 .gif 
Image5 . gif 
Image6.gif 
image7 . gif 
Image9 . gif 
imageUUV. gif 
localserver . ini 
login . gif 
open_act.gif 
RE ADME_E XAM PLE 5 . txt 
reconnect . gif 
runbroker2 .bat 
runbrokerl.bat 
runserver.bat 
sample . j serv . properties 
sell . gif 
sharebroker.bat 
sharebroker2 .pr 
shareBrokerlnt f . pro 
ShareBrokerService2 .xml 
sharebrokerl . pr 
ShareBrokerServicel . xml 
ShareBrokerVocabulary . xml 
stocktrade.bat 
StockTrade.html 
stocktrade . pr 
title.gif 
trader .pro 
Trader .xml 
traderlntf .pro 



12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:26p 
04:26p 
04:26p 
04:26p 
63 



File (s) 



test 

1,253 TraderVocabulary.xml 
1,118 TraderService.xml 

314 upload.gif 

285 watch.gif 
220,512 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\c 
onf ig\example5\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:22p 
06:22p 
06:22p 
6 



<DIR> 
<DIR> 



2, 999 
64 
46 
846 



File(s) 



Entries 

Repository 

Root 

Template 



3,955 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\C 



■552/06/00 

!lfe/06/00 
iffe/16/99 
fe/16/99 
112/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:22p 
06:23p 
06:22p 
06:22p 
06:22p 
7 



<DIR> 
<DIR> 



File (s) 



186 Entries 
42 Entries. Log 
48 Repository 
4 6 Root 

84 6 Template 
1,168 bytes 



jjpirectory of E : \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\d 

ip 

Ip/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> CVS 

12/07/99 04:26p 1,806,132 ShareBrokerDocs.zip 

4 File(s) 1,806,132 bytes 

Directory of E : \e-speak-src_991217 \platf orm\ES\tutorial\sharebroker\d 
oc\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:23p 
06:22p 
06:22p 
06:22p 
6 



<DIR> 
<DIR> 



File(s) 



59 Entries 
52 Repository 
4 6 Root 
84 6 Template 
1,003 bytes 
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test 



Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\s 
rc 



12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 


CVS 


12/06/00 


04 


: 33p 


<DIR> 


examplel 


12/06/00 


04 


: 33p 


<DIR> 


example2 


12/06/00 


04 


: 33p 


<DIR> 


example3 


12/06/00 


04 


: 33p 


<DIR> 


example4 


12/06/00 


04 


:33p 


<DIR> 


example5 






8 


File (s) 


0 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\s 
rc\CVS 



12/06/00 
,3,2/06/00 
&/16/99 
$2/16/99 
|fe/16/99 
$2/16/99 
$2/16/99 



04:33p 
04 :33p 
06:23p 
06:23p 
06:23p 
06:23p 
06:23p 
7 



<DIR> 
<DIR> 



File (s) 



3 Entries 
90 Entries. Log 
52 Repository 
4 6 Root 
84 6 Template 
1,037 bytes 



rjpAexamplel 








ft/06/00 


04 


: 33p 


<DIR> 




ft/06/00 


04 


: 33p 


<DIR> 




1-2/07/99 


04 


: 26p 




4,723 


ft/07/99 


04 


:26p 




4, 109 


12/07/99 


04 


:2 6p 




353 


12/06/00 


04 


:33p 


<DIR> 




12/07/99 


04 


: 26p 




361 



7 File(s) 



BankVocabulary . java 
BankVocabFinder . j ava 
compile.bat 
CVS 

Makefile 
9,546 bytes 



Directory of E: \e-speak-src_9 9121 7 \platform\ES\ tutor ial\sharebroker\s 
rc\examplel\CVS 



12/06/00 04:33p <DIR> 
12/06/00 04:33p <DIR> 

12/16/99 06:23p 209 Entries 

12/16/99 06:23p 61 Repository 

12/16/99 06:23p 46 Root 

12/16/99 06:23p 846 Template 

6 File(s) 1,162 bytes 
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test 



rc\example2 




lz / U b/ UU 


n /i 
U4 


:33p 


lz / U b/ UU 


n /1 
U4 


:33p 


1 0 /n~7 yon 

iz/u / / y y 


U4 


:27p 


iz / u / / y y 


U4 


:27p 


10 f c\h / n n 

iz/u / /yy 


n a 
04 


:27p 


10 / r\n / n n 

iz/u //yy 


n /i 
04 


:27p 


±1/01/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


iz / u / / y y 


n a 
U 4 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/06/00 


04 


:33p 


12/07/99 


04 


:27p 


,42/07/99 


04 


:27p 


12/07/99 


04 


:27p 


|2/07/99 


04 


:27p 


£2/07/99 


04 


:27p 


1=2/07/99 


04 


:27p 



<DIR> 
<DIR> 



<DIR> 



19 File(s) 



3,326 AccountNumberGenerator . java 

1,930 Address. esidl 

6,326 BankClient • java 

2,748 BankServicelntf .esidl 

3,192 BankServicelntf Finder . java 

15,603 BankServicelmpl . java 

4,094 BankService. java 

4,7 31 BankVocabulary . java 

1,823 Company . esidl 

4 91 compile.bat 
CVS 

1,007 Makefile 

2,063 OrderDetailParam. esidl 

2,275 Semaphore . j ava 

2,003 ShareDetailParam. esidl 

3, 223 ShareDetail. java 

2,461 UserAccount . j ava 
57,296 bytes 



^Directory of E : \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\ 
; rc\example2 \CVS 



HE/06/00 


04 


: 33p 


312/06/00 


04 


: 33p 


12/16/99 


06 


:23p 


|2/16/99 


06 


:23p 


112/16/99 


06 


:23p 


12/16/99 


06 


:23p 
6 


Directory of E: 


rc\example3 




12/06/00 


04 


: 33p 


12/06/00 


04 


: 33p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 



<DIR> 
<DIR> 



File(s) 



874 Entries 
61 Repository 
4 6 Root 
84 6 Template 
1,827 bytes 



<DIR> 
<DIR> 



3,325 AccountNumberGenerator . java 

5,7 73 AddFundsGUI . java 

1,930 Address. esidl 

8,140 AddSharesGUI . java 

10,909 AuthorizationWindow. java 

2,783 BankServicelntf .esidl 

3,119 BankServicelntf Finder . java 
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12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/06/00 04:33p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/15/99 04:00p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

f2/07/99 04:27p 

lfe/07/99 04:27p 

ife/07/99 04:27p 

i2/07/99 04:27p 

1-2/07/99 04:27p 

lJ/07/99 04:27p 

12/07/99 04:27p 

1,2/07/99 04:27p 

|?/07/99 04:27p 

Jtl/07/99 04:27p 

SI/07/99 04:27p 

$2/07/99 04:27p 

B/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

46 File(s) 



test 

14,971 BankServicelmpl . java 

4.083 BankService. java 
4,723 BankVocabulary . java 

18,119 BrokerLogic. java 

10,571 BuySharesGUI. java 
7,17 0 ChangePasswordGUI . java 
1,819 Company . esidl 
68 9 compile.bat 
<DIR> CVS 

9,308 ListAccountGUI. java 

18,944 ListSharesGUI. java 
7,871 LoginGUI. java 
2,405 Makefile 
1,901 Mat chThread. java 
5,656 MessageDialog. java 
7,592 OpenAccountGUI . java 
2,063 OrderDetailParam. esidl 
3,610 OrderDetail. java 
9,68 6 SellSharesGUI. java 
2,27 9 Semaphore. java 
2,650 ServiceDeployer. java 
2,225 ShareBrokerlntf .esidl 
3,256 ShareBrokerlntf Finder. java 
4,600 ShareBrokerlmpl . java 
2,046 ShareDetailParam. esidl 
3,223 ShareDetail. java 
4,44 9 StartShareBrokerService. java 
6,322 StartTraderService. java 

23,802 StockTrade. java 
1,921 TraderQuerySpec. esidl 

4.84 0 TraderVocabulary. java 
1,948 Traderlntf. esidl 
2,731 TraderService . java 
4,384 Traderlntf Finder. java 
2,979 Trader Impl. java 
1,969 Transaction. esidl 

2,4 59 UserAccount . java 
245,243 bytes 



Directory of E:\e-speak-src_991217\platform\ES\tutorial\sharebroker\s 
rc\example3\CVS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:23p 
06:23p 
06:23p 
06:23p 



<DIR> 
<DIR> 



2,389 Entries 
61 Repository 
4 6 Root 
84 6 Template 
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6 File(s) 



test 
3,342 bytes 



rc\example4 




19 /ofi/oo 


o & 


: 33p 


i 9 /of* /on 


0 A 
U 4 


: 33p 


1 9/01 / QQ 


0/1 
U H 


:27p 


1 ? /D7 /QQ 
x^l / u / / y y 


Pi A 
U 4 


:27p 


1 9 /07 / QQ 
JLZ / U / / y y 


0 A 
U 4 


:27p 


19/07/QQ 
±/L / kj i / yy 


0 4 
u 4 


:27p 


1 9 /07 / QQ 
±Z / U / / y y 


0 /l 
U 4 


:27p 


19/07/QQ 
-LZ / U / / y y 


0 /l 
U 4 


:27p 


1 9 /07 / Q Q 
±£ / v f / y y 


0 A 

U 4 


:27p 


1 9 /07 / QQ 
_LZ / U / / y y 


O A 


:27p 


19/07/QQ 
±Z / u / / y y 


0 /I 
U 4 


:27p 


1 9 / m / QQ 

iz / u / / y y 


U 4 


:27p 


1 9 / 0 7 / QQ 
±£ / U / / yy 


O /I 

U4 


:27p 


1 9 / 0 7 / QQ 
/ U / / y y 


n a 
U4 


:27p 


*fh / n 7 / QQ 

/ U / / yy 


u 4 


:27p 


f'O /07 / QQ 


o yi 
U4 


:27p 


Xb / 0 7 / Q Q 


O A 

U4 


:27p 


St? /07 /QQ 


O/l 
U 4 


:27p 


Hlb / n £ / n n 

Js Z / UD / UU 


O A 
U fl 


: 33p 


ftp / 07 / Q Q 


O A 


:27p 


1-9 / 0 7 / Q Q 

/ u / / y y 


O /I 
U 4 


:27p 


19 /07 / QQ 

4- z / u / / yy 


O A 


:27p 


1O/07/QQ 
4#*£ / U I f yy 


O /I 
U 4 


:27p 


%9 /0 7 /QQ 
4= |. / U 1 / yy 


O A 
U 4 


:27p 


1*9 / 0 7 / Q Q 

jtz /u / /yy 


O A 
U4 


:27p 


p£ / ID / yy 


O A 
U 4 


: OOp 


i*b / n 7 /qq 


0 ZL 
U 4 


:27p 


lSf> / 0 7 / Q Q 

i 4- / u / / y y 


O A 

U 4 , 


:27p 


19 / 0 7 / Q Q 

xz/u / / yy 


u 4 , 


:27p 


1 9 /07 / QQ 

xz/u // yy 


O A < 
U4 , 


:27p 


12/07/99 


04; 


:27p 


12/07/99 


04: 


:27p 


12/07/99 




. z /p 


12/07/99 


04: 


:27p 


12/07/99 


04: 


:27p 


12/07/99 


04: 


:27p 


12/07/99 


04: 


:27p 


12/07/99 


04: 


:27p 


12/07/99 


04: 


;27p 


12/07/99 


04: 


27p 


12/07/99 


04: 


27p 


a 

12/07/99 


04: 


27p 



<DIR> 
<DIR> 

3,407 AccountNumberGenerator . java 

5,82 9 AddFundsGUI. java 

1,930 Address. esidl 

8,196 AddSharesGUI. java 
10,880 AuthorizationWindow. java 

2,783 BankServicelntf .esidl 

6,052 BankServicelntfFinder . java 
17,695 BankServicelmpl . java 

4,392 BankService. java 

4,718 BankVocabulary . java 
33,103 BrokerLogic. java 
10,530 BuySharesGUI. java 

5,975 CancelOrderGUI . java 

7,389 ChangePasswordGUI . java 

1,819 Company . esidl 
691 compile.bat 
<DIR> CVS 

2.04 9 Helper. java 

9,303 ListAccountGUI . java 
6,758 ListBanksGUI . java 
7,518 ListBrokersGUI . java 
18,889 ListSharesGUI. java 
7,920 LoginGUI. java 
2,835 Makefile 
1,901 MatchThread. java 
5,657 MessageDialog. java 
3,255 MessageClient . java 
7,618 OpenAccountGUI . java 
2,065 OrderDetailParam. esidl 
3,178 OrderDetail. java 
2,054 ReqAuthThread. java 
7,236 SelectBankGUI. java 
9,890 SellSharesGUI. java 
2 , 277 Semaphore . j ava 

3 . 005 ServiceDeployer . j ava 
2,537 ShareBrokerlntf .esidl 
6,943 ShareBrokerlntf Finder. java 
6,917 ShareBrokerlmpl. java 

2,259 ShareBrokerEventDistributor . jav 

2,048 ShareDetailParam. esidl 
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1 6S t 




1 9 /07 /QQ 




• Z. f p 


O /■ O 


OilciJLt.Uti L-ci-L-L. ■ Java 


1 9 /CM /QQ 
XZ / U / / 


n a 

U 4 


. z /p 


D f D / O 


O 4" ^ >~ 4— O V> —v -v- r-i O v* f~\ \y /~\ V" C! f~\ V* TT 1 / — l /— \ —l 1 TT 

o tdrLonareDroKeroervice . javci 


19/0 7/QQ 


U 4 


. z / p 




O 4— —| 4— T 1 V* "~1 /"S "V* O / — \ V>Tt T /-* r~\ —I 

oLdiui rausrosrvi ce . j ava 


1 9 /07 /QQ 
xz/u / /_?:? 


Od 

V H 


• 9 7n 

. z / p 


^ 9 HA 
O ^ Z U fi 


JldLUovVlIlQOW . Java 


1 9 /m /QQ 
1/ / U I / yy 


C\A 


. z /p 


9 £ DOR 
Z O / O Z 0 


oiocKi raae - 3 ava 


1 9 /H 7 / QQ 

x z / u / / 


n a 

U 4: 


• 97r^ 

. z /p 


1 Q /I £ 

x z y ft d 


1 raueryueryopBC . esiux 


1 9 /m / QQ 
XZ/ U / / yy 




. z /p 


*5 Q9 Q 

o f yz y 


1 raaer xnu 1 r masr , 3 ava 


1 9 /CM / Q Q 
1Z, / u / / y y 




• 9 7r^ 

. z / p 


9 hp n 
z r u o u 




12/07/99 


04 


:27p 


3,774 


Trader Impl . j ava 


12/07/99 


04 


:27p 


5,030 


TraderVocabulary . java 


12/07/99 


04 


:27p 


2,730 


TraderService . j ava 


12/07/99 


04 


:27p 


1, 969 


Transaction . esidl 


12/07/99 


04 


:27p 


2,461 


UserAccount . j ava 



55 File(s) 321,699 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\s 
rc\example4 \CVS 

.12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

ft/16/99 06:23p 2,891 Entries 

12/16/99 06:23p 61 Repository 

J'2/16/99 06:23p 46 Root 

ifiS/16/99 06:23p 846 Template 

% 6 File(s) 3,844 bytes 

^Directory of E : \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\s 



£c\example5 








ii/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


:33p 


<DIR> 




J2/07/99 


04 


:27p 


3,408 


AccountNuraberGenerator . j ava 


M/07/99 


04 


:27p 


5,120 


AddFundsGUI . j ava 


rl/07/99 


04 


:27p 


2, 629 


AddFundServlet . j ava 


12/07/99 


04 


:27p 


1, 932 


Address . esidl 


12/07/99 


04 


:27p 


3,248 


AddSharesServlet . j ava 


12/07/99 


04 


:27p 


7,505 


AddSharesGUI . j ava 


12/07/99 


04 


:27p 


11, 907 


AuthorizationWindow. java 


12/07/99 


04 


:27p 


3,870 


AuthoriseOrderServlet . j ava 


12/07/99 


04 


:27p 


2,783 


BankServicelntf . esidl 


12/07/99 


04 


:27p 


9,119 


BankServicelntf Finder .java 


12/07/99 


04 


:27p 


17,380 


BankServicelmpl . j ava 


12/07/99 


04 


:27p 


4, 436 


BankService . j ava 


12/07/99 


04 


:27p 


4,907 


BankVocabulary . j ava 


12/07/99 


04 


:27p 


33,346 


BrokerLogic . j ava 


12/07/99 


04 


:27p 


3,346 


BuySharesServlet . j ava 


12/07/99 


04 


:27p 


9,070 


BuySharesGUI . j ava 


12/07/99 


04 


:27p 


2,443 


CancelOrderServlet . j ava 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
©2/07/99 
ife/07/99 
lfe/07/99 
#2/07/99 
^2/07/99 
12/15/99 
3fe/07/99 
12/07/99 
12/07/99 
12/07/99 
32/07/99 
12/07/99 
lfe/07/99 
f|/07/99 
§2/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
a 



04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:33p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04 :27p 
04:27p 
04 : OOp 
04:27p 
04 :27p 
04:27p 
04:27p 
04:27p 
04:27p 
04 :27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04 :27p 
04:27p 
04:27p 



<DIR> 



test 


5/ 


803 


2, 


731 


7, 


361 




R R 1 

O O X 


o f 




i 

X / 


R 9 "3 

O Z O 




(TQQ 
DO!? 


o 

<L f 




9 

r 


O O U 


1 

X / 


R 90 

O -7 u 


9 
z t 


04 Q 


o 

Z f 


£9 1 


R 


£7 Q 


9 

Z t 


^7 1 
0 / X 


7 


471 
4 / X 


9 

Z ; 


coo 
000 


9 
Z / 


77 R 


p 

O ; 


1 OP 
X U O 


3 t 


9 01 
Z U X 


1 7 
X / f 


0 Q R 
U :? 0 


O i 


70c 
/JO 


7 


coi 
Oil 


Z f 


0 U X 


O t 


0 Q 1 


1 

X f 


Q 0 1 
U X 


9 


19 9 


c. 

■J f 


67 R 


A 


0R4 


c; 

•j f 


QOR 

r U O 


9 

z. t 


669 
r UUZ, 


Q 

O f 


QQO 


9 
£* i 


1 06 

r X U U 


9 

£~ t 


064 

r \J U *i 




1 P9 

r X O Z 


X / 


R Q1 

r U J? X 


9 


6^ Q 

t D U _7 


O 

£~ t 


0 R 4 


7 
/ f 


1 9 Q 

r X Z J7 


9 

o t 


9 1 S 

r Z X O 


Q 


yi O 9 


2, 


,275 


2, 


. 598 


2, 


,535 


9, 


, 723 


7, 


,299 


2, 


,261 



CancelOrderGUI . j ava 

ChangePasswordServlet . j ava 

ChangePasswordGUI . j ava 

CheckSharesThread . j ava 

CheckSharesServlet , j ava 

Company . esidl 

compile.bat 

Connect ionClass . j ava 

CVS 

Encoder . java 

GetShareBrokerListServlet . java 
Helper. java 

ListAccountSharesServlet . j ava 
ListAccountGUI . java 
ListAccountBalanceServlet . j ava 
ListBanksGUI .java 
ListBanksServlet . java 
ListBrokersServlet . j ava 
ListBrokersGUI . java 
ListSharesServlet . java 
ListSharesGUI .java 
ListShareBrokersGUI . java 
LoginGUI . java 
LoginServlet . j ava 
Makefile 

MatchThread . j ava 
MessageDump. java 
MessageDialog. java 
MessageClient . j ava 
Message. java 
OpenAccountServlet . j ava 
OpenAccountGUI . j ava 
OrderCollection. java 
OrderDetailParam. esidl 
OrderDetail . j ava 
QuerySpec . esidl 
QuerySpec* java 
ReqAuthThread. java 
SelectBankGUI . java 
SellSharesServlet . java 
SellSharesGUI. java 
Semaphore . j ava 
ServiceDeployer . j ava 
ShareBrokerlntf . esidl 
ShareBrokerlntf Finder .java 
ShareBrokerlmpl . j ava 
ShareBrokerEventDistributor . jav 
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12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04 :27p 
04:27p 
04:27p 

81 File(s) 



test 

2,045 ShareDetailParam.esidl 

3,565 ShareDetail . java 

6,741 StartShareBrokerService . j ava 

5, 365 StartTraderServiceServlet .java 

3,254 StartTraderService. java 

4,708 StatusWindow. java 
29,153 StockTrade. java 

1,945 TraderQuerySpec.esidl 

5,059 TraderVocabulary. java 

2,078 Traderlntf .esidl 

2,729 TraderService. java 

3,944 Traderlntf Finder. java 

3,614 Traderlmpl . java 

1,986 Transaction. java 

2,545 UserAccount . java 
403,670 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\sharebroker\s 
,=&c \ e x amp 1 e 5 \ C V S 



12/06/00 
life / 0 6 / 0 0 
&/16/99 
$2/16/99 
12/16/99 
£22/16/99 



04:33p 
04:33p 
06:23p 
06:23p 
06:23p 
06:23p 
6 



<DIR> 
<DIR> 



File(s) 



4,413 Entries 
61 Repository 
4 6 Root 
84 6 Template 
5,366 bytes 



directory of E: \e-spea k-sr c_9 9 12 1 7 \pla tform\ES\ tutorial \usedcar sale 



12/06/00 


04 


: 33p 


<DIR> 




&/06/00 


04 


:33p 


<DIR> 




ft/07/99 


04 


:27p 




1,208 


12/06/00 


04 


: 33p 


<DIR> 


12/06/00 


04 


: 33p 


<DIR> 




12/06/00 


04 


: 33p 


<DIR> 




12/07/99 


04 


:27p 




229 


12/07/99 


04 


:27p 




5, 938 


12/07/99 


04 


:27p 




126 


12/07/99 


04 


:27p 




472 


12/07/99 


04 


:27p 




5, 923 


12/07/99 


04 


:27p 




10, 177 


12/06/00 


04 


: 33p 


<DIR> 




12/07/99 


04 


:27p 




2,892 


12/07/99 


04 


:27p 




2, 152 


12/07/99 


04 


:27p 




6 


12/06/00 


04 


: 33p 


<DIR> 





conf ig 

CVS 

html 



17 File(s) 



servlets 



src 

29,123 bytes 
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test 



onf ig 






12/06/00 


04 


:33p 


12/06/00 


04 


: 33p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/06/00 


04 


: 33p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


11/07/99 


04 


:27p 



<DIR> 
<DIR> 



<DIR> 



16 File(s) 



117 Buyerl.pr 

97 Buyer2.pr 

73 CarAd.pr 

105 CarBroker2 .pr 

132 CarBrokerl .pr 

22 co.MYCOl 

22 co.MYCO 
CVS 

1,129 input. ptml 

129 Payment. pr 

737 response . ptml 

99 Sellerl.pr 

97 Seller2.pr 

141 SendMailServer.pr 
2,900 bytes 



^Directory of E : \e-spea k-src_9 9 12 17 \platform\ES\ tutorial \usedcarsale\c 
&&fig\CVS 



T2/06/00 
12/06/00 
12/16/99 
15/16/99 
it/16/99 
flS/16/99 



04:33p 
04:33p 
06:23p 
06:23p 
06:23p 
06:23p 
6 



<DIR> 
<DIR> 



File (s) 



621 Entries 
55 Repository 
4 6 Root 

846 Template 
1,568 bytes 



"Directory of E: \e-speak-src_991217\platform\ES\tutorial\usedcarsale\C 
VS 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:23p 
06:23p 
06:23p 
06:23p 
06:23p 
7 



<DIR> 
<DIR> 



File (s) 



495 Entries 
61 Entries. Log 
48 Repository 
4 6 Root 

846 Template 
1,496 bytes 



Directory of E : \e-speak-src_991217\platf orm\ES\tutorial\usedcarsale\h 
tml 
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12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/06/00 04:33p <DIR> 

12/06/00 04:33p <DIR> 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

f'2/07/99 04:27p 

12/07/99 04:27p 

12/07/99 04:27p 

BS/07/99 04:27p 

12/07/99 04:27p 

K/07/99 04:27p 

, 26 File(s) 



test 



5,634 AdvertiseToSell.html 

1.828 BuyerFirstScreen.html 
2,456 BuyerLogin2.html 
2,456 BuyerLoginl.html 
1,757 buyerops.html 

2,660 BuyerRegister2.html 

2.660 BuyerRegisterl.html 
1,878 CarbrokerFirstScreen2.html 
1,87 6 CarbrokerFirstScreenl.html 
3,4 69 choice2.html 

3,4 69 choicel.html 
CVS 

images 
14,010 newcarsales.html 
1,824 SellerDetails.html 
1,888 SearchForSellers.html 
2,456 SellerLoginl.html 

1.829 SellerFirstScreen.html 

2.661 SellerRegister2.html 
2,661 SellerRegisterl.html 
1,661 sellerops.html 
2,458 SellerLogin2.html 
1,343 thanks.html 

20,513 webdemo.html 
83,447 bytes 



iipirectory of E : \e-spea k- s rc_9 9 12 1 7 \platform\ES\ tutorial \usedcar sale \h 
tMl\CVS 



H/06/00 
tt/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04:33p 
06:23p 
06:23p 
06:23p 
06:23p 
06:23p 
7 



<DIR> 
<DIR> 



File (s) 



1,205 Entries 

16 Entries. Log 
53 Repository 
4 6 Root 
84 6 Template 
2,166 bytes 



Directory of E: \e-speak-src_9 9 12 17 \platform\ES\ tutorial \usedcarsale\h 
tml\ images 



12/06/00 
12/06/00 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:27p 
04:27p 
04:27p 



<DIR> 
<DIR> 



13,761 buy.jpg 
11,004 car3_anm.gif 
19,273 carbroker.jpg 

Page 128 



12/06/00 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:27p 
04:27p 
04:27p 
04:27p 
04 :27p 
04 :27p 
04:27p 
04:27p 
04:27p 
04:27p 
04 :27p 
04 :27p 
04:27p 
04:27p 
04:27p 
04:27p 
04:27p 
04 :27p 

24 File(s) 



<DIR> 



test 

52 
2,578 
82,264 
971 
971 
98, 743 
160,012 
161, 302 
110, 035 
123, 161 
128, 175 
131, 157 
141, 087 
157, 932 
161,582 
159,451 
7, 986 
398 
1,671,895 



CVS 

espeak. JPG 
happy . gif 
interact . jpg 
left-hand. gif 
right-hand . gif 
si. jpg 
slO . jpg 
sll . jpg 
s2.jpg 
s3 . jpg 
s4.jpg 
s5 . jpg 
s6 . jpg 
s7.jpg 
s8 . jpg 
s9.jpg 
seller. jpg 
visal_60x38_a.gif 
bytes 



^Directory of E:\e-speak-src_991217\platform\ES\tutorial\usedcarsale\h 
ifml\images\CVS 



12/06/00 
12/06/00 
12/16/99 
0,2/16/99 
S2/16/99 
ft/16/99 



04:33p 
04:33p 
06:23p 
06:23p 
06:23p 
06:23p 
6 



<DIR> 
<DIR> 



File(s) 



965 Entries 
60 Repository 
4 6 Root 
84 6 Template 
1,917 bytes 



iipirectory of E: \e-speak-src_9 9 12 17 \platform\ES\ tutorial \usedcar sale \s 
ervlets 



12/06/00 
12/06/00 
12/07/99 
12/06/00 
12/15/99 
12/07/99 
12/07/99 
12/07/99 
12/07/99 



04:33p 
04:33p 
04:27p 
04 :33p 
04 :00p 
04:27p 
04:27p 
04:27p 
04:27p 
9 



<DIR> 
<DIR> 

<DIR> 



File (s) 



88 0 compile.bat 
CVS 

663 Makefile 
4,158 Register . java 
38,178 RunCarSellerClient . java 
4 6,235 RunCarBuyerClient . java 
13,415 RunCarBrokerService . java 
103,529 bytes 



Directory of E: \e-speak-src_991217\platf orm\ES\tutorial\usedcarsale\s 
ervlets\CVS 
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test 



12/06/00 
12/06/00 
12/16/99 
12/16/99 
12/16/99 
12/16/99 



04:33p 
04 :33p 
06:2 3p 
06:23p 
06:23p 
06:23p 

6 File(s) 



<DIR> 
<DIR> 



326 Entries 
57 Repository 
4 6 Root 

84 6 Template 
1,275 bytes 



Directory of E : \e-speak-src_991217 \platf orm\ES\tutorial\usedcarsale\s 



rc 






12/06/00 


04 


: 3 3p 


12/06/00 


04 


: 33p 


12/07/99 


04 


: 27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


A2/07/99 


04 


:27p 


Jfe/07/99 


04 


:27p 


$2/07/99 


04 


:27p 


lfe/07/99 


04 


:27p 


ife/07/99 


04 


:27p 


!ife/07/99 


04 


:27p 


32/06/00 


04 


: 33p 


ii^/07/99 


04 


:27p 


12/15/99 


04 


:00p 


12/07/99 


04 


:27p 


42/07/99 


04 


:27p 


ft/07/99 


04 


:27p 


Ife/07/99 


04 


:27p 


ft/07/99 


04 


:27p 


tt/07/99 


04 


:27p 


f2/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 


12/07/99 


04 


:27p 



<DIR> 
<DIR> 



<DIR> 



29 File(s) 



11,086 BrokerManager . java 
2,088 Buyerlnfo.esidl 

19,355 BuyerManager . java 
2,416 CarAdlnt f . esidl 

13,041 CarAdlmpl. java 
2,902 CarBrokerlntf .esidl 

15,108 CarBrokerlmpl. java 
2,416 CarDetails. esidl 
1,556 compile.bat 
2, 929 Constants . j ava 
CVS 

2,137 DealDetails. esidl 
2,078 Makefile 
2,094 Payment Intf .esidl 
6,501 PaymentServer . java 
3,322 Payment Impl . j ava 
2,071 PTML. esidl 
2,152 Sellerlntf .esidl 

21,491 SellerManager. java 
2,190 Sellerlnfo. esidl 
8,164 Sellerlmpl. java 
2,259 SendMaillntf .esidl 
4,043 SendMailServer . java 
3,714 SendMaillmpl . java 
6,565 ServiceStopper . java 
2,367 Stoppable . j ava 
3,580 Util.java 

147,625 bytes 



Directory of E : \e-spea k- sr c_9 9 12 1 7 \pla t f orm\ES\ tutorial \usedcar sale \s 
rc\CVS 



12/06/00 04:33p 
12/06/00 04:33p 



<DIR> 
<DIR> 
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12/16/99 06:23p 
12/16/99 06:23p 
12/16/99 06:23p 
12/16/99 06:23p 
6 

Total Files 
4189 



File (s) 
Listed: 

File(s) 18 



test 

1,369 Entries 
52 Repository 
4 6 Root 
84 6 Template 
2,313 bytes 



116,673 bytes 

0 bytes free 
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